如何打印首尾元素不相同的数字金字塔图案

来源:站长素材作者:弥生美月头衔:网络博主
导读:本期聚焦于小伙伴创作的《如何打印首尾元素不相同的数字金字塔图案》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《如何打印首尾元素不相同的数字金字塔图案》有用,将其分享出去将是对创作者最好的鼓励。

打印首尾元素不相同的数字金字塔图案,核心是先确定金字塔的层级结构,再对每一行的首尾数字做差异化处理,避免两者取值相同。这类问题常见于编程基础练习,主要考察循环嵌套和条件判断的综合运用能力。

如何打印首尾元素不相同的数字金字塔图案

需求分析

首先明确数字金字塔的基本规则:假设金字塔共有n行,第i行(从1开始计数)的数字个数为2i-1个,数字通常从1开始递增,中间位置的数字最大。在此基础上增加约束:每一行的第一个数字和最后一个数字不能相等。

常规的数字金字塔第i行的首尾数字均为1,显然不符合要求,因此需要对首尾数字的取值做调整,比如让首数字保持为1,尾数字从2开始递增,或者根据行数做其他规则设定,只要保证两者不同即可。

实现思路

  • 外层循环控制金字塔的行数,从1遍历到n
  • 内层第一个循环打印每行前面的空格,保证金字塔的对齐效果,第i行前面的空格数为n-i个
  • 内层第二个循环打印每行的数字,先处理首尾数字:首数字固定为1,尾数字根据行数计算,保证和首数字不同
  • 中间的数字按照常规金字塔规则递增,中间位置的数字为i

Python实现示例

以下是Python语言实现打印5行首尾元素不同的数字金字塔的代码:

# 定义金字塔行数
n = 5
for i in range(1, n + 1):
    # 打印前面的空格
    for space in range(n - i):
        print(" ", end="")
    # 打印当前行的数字
    for num in range(1, 2 * i):
        # 第一个数字,固定为1
        if num == 1:
            print(1, end="")
        # 最后一个数字,行数大于1时设为i+1,保证和首数字1不同
        elif num == 2 * i - 1:
            if i == 1:
                # 第一行只有1个数字,首尾相同,单独处理
                print(1, end="")
            else:
                print(i + 1, end="")
        # 中间的数字,中间位置为i,其余按规则递增
        else:
            if num <= i:
                print(num, end="")
            else:
                print(2 * i - num, end="")
    # 每行打印完成后换行
    print()

运行上述代码后,输出的金字塔图案如下:

    1
   1 2 1
  1 2 3 2 1
 1 2 3 4 3 1
1 2 3 4 5 4 1

Java实现示例

同样的逻辑用Java实现,代码如下:

public class NumberPyramid {
    public static void main(String[] args) {
        int n = 5;
        for (int i = 1; i <= n; i++) {
            // 打印前面的空格
            for (int space = 0; space < n - i; space++) {
                System.out.print(" ");
            }
            // 打印当前行的数字
            for (int num = 1; num <= 2 * i - 1; num++) {
                if (num == 1) {
                    System.out.print(1);
                } else if (num == 2 * i - 1) {
                    if (i == 1) {
                        System.out.print(1);
                    } else {
                        System.out.print(i + 1);
                    }
                } else {
                    if (num <= i) {
                        System.out.print(num);
                    } else {
                        System.out.print(2 * i - num);
                    }
                }
                // 数字之间加空格分隔,更美观
                if (num != 2 * i - 1) {
                    System.out.print(" ");
                }
            }
            System.out.println();
        }
    }
}

注意事项

  • 当金字塔只有1行时,只有一个数字,首尾元素必然相同,需要单独做逻辑处理,避免报错
  • 打印空格和数字时,要注意不要多余换行,保证图案的对齐效果
  • 如果调整首尾不同的规则,比如首数字随行数变化,只需要修改对应位置的条件判断即可,整体结构不需要大改

这类图案打印问题的核心是理清循环层级和每个位置的数字生成规则,只要拆分清楚每一步的逻辑,就能快速写出正确的代码。

数字金字塔循环结构条件判断控制台输出修改时间:2026-07-05 03:30:22

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。