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

本文详解如何用嵌套循环生成特定递增规律的三角形数字图案,重点解决“每行起始与结束数字不同”这一常见逻辑难点,并提供可复用的代码模板与格式化技巧。

要实现如下的目标图案:

1
3 5
5 8 11
7 11 15 19
9 14 19 24 29

关键在于理解其数学规律:

  • 第 i 行有 i 个数字;
  • 每行首项为 2*i - 1(即第1行首项=1,第2行=3,第3行=5…);
  • 每行公差固定为 i(第1行公差=1,第2行=2,第3行=3…),因此第 i 行第 j 个数可表示为:
    a[i][j] = (2*i - 1) + (j - 1) * i

但更简洁、符合原题思路的实现方式是将行首值作为初始 p,并在内层循环中以当前行号 i 为步长累加。注意:原题错误在于 k 和 p 的更新时机混乱(p 在内层累加却依赖全局 k,且 k++ 放在行末导致跨行干扰)。正确做法是:

✅ 每行独立初始化 p(取自行首基准值);
✅ 内层每次加的是该行固定的增量(即 i);
✅ k 仅用于生成首项,可直接用 2*i - 1 替代,或按答案中用前置自增模拟。

以下是推荐的清晰实现:

for (int i = 1; i <= 5; i++) {
    int p = 2 * i - 1; // 当前行首数字:1, 3, 5, 7, 9
    for (int j = 1; j <= i; j++) {
        System.out.print(p);
        if (j < i) System.out.print(" "); // 避免行末多余空格
        p += i; // 每次加 i(第 i 行的公差)
    }
    System.out.println();
}

输出完全匹配目标:

1
3 5
5 8 11
7 11 15 19
9 14 19 24 29

? 进阶提示:若需对齐显示(尤其数字位数增加后),建议使用 printf 控制宽度:

System.out.printf("%-4d", p); // 左对齐,占4字符宽

并在每行末调用 System.out.println() 前添加换行。

⚠️ 常见误区总结

  • ❌ 在外层循环外定义并复用 p 变量(导致跨行污染);
  • ❌ 将步长 k 与行索引 i 混淆,未明确“每行应有独立增量”;
  • ❌ 忽略输出格式细节(如末尾空格、对齐),影响可读性。

掌握“行内独立状态 + 行间参数解耦”这一思想,即可灵活构造各类非等差三角形图案。