如何打印首尾元素不相同的递增数字三角形图案

本文详解如何通过调整变量作用域与更新时机,生成每行首尾元素不同的数字三角形图案,重点解决循环中累加逻辑错位导致的输出偏差问题。

在打印数字三角形图案时,一个常见误区是将累加变量(如 p)声明在最外层循环之外,并在内层循环中持续修改,导致后续行的起始值被前一行“污染”。题中原始代码的问题正在于此:p 是全局累加的,且 k++ 发生在每行结束后,使得每行的初始值并非独立可控,最终输出的各行首尾元素虽递增但不符合目标规律。

要实现目标输出:

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行:5−3=2 → 实际差值 = i?再验证:第3行 8−5=3,11−8=3 → 差值 = i;第4行 11−7=4,15−11=4 → 差值 = i;第5行 14−9=5 → 确实,行内公差 = 当前行号 i);
  • 因此,第 i 行第 j 个数可表示为:
    value = (2*i - 1) + (j - 1) * i

但更简洁、符合原答案思路的实现方式是:让每行拥有独立的起始值 p,该值由外层变量 k 初始化,且 k 在每行开始前自增,确保逐行递进

✅ 正确代码如下(含格式优化):

int k = 0;
for (int i = 1; i <= 5; i++) {
    int p = k++;  // 每行独立初始化 p,k 先赋值后自增 → 第

1行 p=0, k→1;第2行 p=1, k→2;... for (int j = 1; j <= i; j++) { p += k; // 当前行公差 = k(此时 k == i,因 k 从 0 开始,第 i 行时 k=i) System.out.printf("%-4d", p); // 左对齐,宽度4,提升可读性 } System.out.println(); }

? 执行逻辑分解(以第3行 i=3 为例)

  • 进入循环前 k = 2(因第1、2行已各执行一次 k++);
  • p = k++ → p = 2, 然后 k 变为 3;
  • 内层循环:
    • j=1: p = 2 + 3 = 5 → 输出 5
    • j=2: p = 5 + 3 = 8 → 输出 8
    • j=3: p = 8 + 3 = 11 → 输出 11
      → 得到 5 8 11,完全匹配目标。

⚠️ 注意事项

  • 切勿复用跨行的累加变量 p,必须在每行内重新声明并初始化;
  • k++ 的位置决定起始值序列:若写成 int p = ++k,则起始值变为 1,2,3...,结果错误;
  • 使用 printf 替代 print 可避免数字右挤、提升对齐效果,尤其在多行对比时更清晰。

总结:此类图案题的核心在于明确每行的数学规律(首项 + 公差),并通过合理的作用域控制变量生命周期。理解 k 作为行号代理与公差提供者的双重角色,是突破“首尾不同却规律统一”类问题的关键。