
本文详解如何用嵌套循环生成特定递增规律的三角形数字图案,重点解决“每行起始与结束数字不同”这一常见逻辑难点,并提供可复用的代码模板与格式化技巧。
要实现如下的目标图案:
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 混淆,未明确“每行应有独立增量”;
- ❌ 忽略输出格式细节(如末尾空格、对齐),影响可读性。
掌握“行内独立状态 + 行间参数解耦”这一思想,即可灵活构造各类非等差三角形图案。











