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

需求分析
首先明确数字金字塔的基本规则:假设金字塔共有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行时,只有一个数字,首尾元素必然相同,需要单独做逻辑处理,避免报错
- 打印空格和数字时,要注意不要多余换行,保证图案的对齐效果
- 如果调整首尾不同的规则,比如首数字随行数变化,只需要修改对应位置的条件判断即可,整体结构不需要大改
这类图案打印问题的核心是理清循环层级和每个位置的数字生成规则,只要拆分清楚每一步的逻辑,就能快速写出正确的代码。