如何生成指定的倒序数字金字塔图案(含上下对称结构)

12次阅读

如何生成指定的倒序数字金字塔图案(含上下对称结构)

本文详解如何用python生成如2、43、765、1110198等逐行递增位数且数字连续倒序排列的对称数字图案,并修正常见循环边界与输出格式错误。

要生成目标图案:

2 43 765 1110198 1110198 765 43 2

关键在于理解该图案的数学规律:

  • 每行数字连续递减,但起始值随行号动态增长;
  • 第1行有1个数字(2),第2行有2个(4,3),第3行有3个(7,6,5),第4行有4个(11,10,9,8);
  • 实际数字序列是全局连续整数:2, 3, 4, 5, 6, 7, 8, 9, 10, 11, …;
  • 每行从该行最大数开始,倒序输出本行所需数量的数字
  • 行数 n = 4 时,共输出 2n 行(上半三角 + 下半三角,含重复中间行)。

✅ 正确实现思路

使用一个累加变量 next_num 记录每行起始数字(即该行最大值),其初始值为 2,每行结束后按行号递增更新:

  • 第 i 行(i 从 0 开始)需输出 i+1 个数字;
  • 起始值 = next_num + i(因为前 i 行已消耗 0+1+2+…+i-1 = i*(i-1)//2 个数,但更直观的是:第0行用1个数(2),第1行用2个数(4,3),故第 i 行最大值 = 2 + (0+1+2+…+i) = 2 + i*(i+1)//2);
  • 倒序范围:range(next_num + i, next_num – 1, -1) → 即从 next_num+i 到 next_num(含),共 i+1 个数;
  • 输出不加空格:end=””;
  • 后续更新 next_num += i + 1,为下一行准备。

✅ 完整可运行代码

n = int(input("Enter the number of rows for the upper half: "))  # Upper half (including middle row) next_num = 2 for i in range(n):     # print i+1 numbers: from (next_num + i) down to next_num     for j in range(next_num + i, next_num - 1, -1):         print(j, end="")     print()  # new line     next_num += i + 1  # Lower half (mirror, excluding middle row) # Reuse same logic but iterate backwards from n-1 down to 1 next_num = 2 for i in range(n - 1, 0, -1):     for j in range(next_num + i - 1, next_num - 1, -1):         print(j, end="")     print()     next_num += i

? 说明:下半部分需重新计算 next_num(或缓存上半部分各起始值),此处采用重算方式确保逻辑清晰。也可提前用列表存储每行首值,再反向遍历。

⚠️ 常见错误纠正

  • range(1, n) 只执行 n-1 次 → 应用 range(n) 实现 n 行;
  • range(i, 0, -1) 终止于 1(不含 0),导致少一位 → 若需包含 next_num,终点应设为 next_num – 1;
  • print(…, end=” “) 引入多余空格 → 目标无分隔,必须用 end=””;
  • 纯靠嵌套 j 循环硬算 j+1 无法匹配全局递增序列 → 必须引入外部状态变量(如 next_num)维护数字流。

✅ 验证示例(n = 4)

输出完全匹配:

2 43 765 1110198 1110198 765 43 2

掌握此模式后,还可轻松扩展为其他变体:如左对齐补空格、添加分隔符、或改为字符序列。核心始终是——分离“数字生成逻辑”与“排版控制逻辑”

text=ZqhQzanResources