1
1 1
1 2 1
1 3 3 1
1 4 6 4 1
1 5 10 10 5 1
1 6 15 20 15 6 1
1 7 21 35 35 21 7 1
1 8 28 56 70 56 28 8 1
1 9 36 84 126 126 84 36 9 1
杨辉三角的特点分析:
1 .当前行的第一位和最后一位都是1
2 .从第三行开始 当前元素的值等于上一行的当前列的值+前一个值
变化值还是2个 .一个行变化,一个列变化.选择双重for循环.代码如下:
package demo0411;
public class 杨辉三角 {
public static void main(String[] args) {.
int[][] arr = new int[10][10];
//创建一个10行10列的数组
for (int j = 0; j < arr.length; j++) {
arr[j][0] = 1;
arr[j][j] = 1;
//保证三角形的最外面的数字全部都是1
}
for (int x = 0; x < arr.length; x++) {
for (int y = 1; y <=x-1; y++) {
//这一步是干嘛的?????
// 这一步的y<x-1,就是保证让从第三行的2开始,当前元素的值等于上一行的当前列的值+前一个值
arr[x][y] = arr[x-1][y-1]+arr[x-1][y];
// 该赋值就是满足 当前元素的值等于上一行的当前列的值+前一个值
}
}
for (int i = 0; i < arr.length; i++) {
for (int j = 0; j <= i; j++) {
System.out.print(arr[i][j]+"\t");
// 这儿的斜杠+t是干嘛的??
//“\t”为“转义字符”,代表的是一个tab,也就是8个空格,
//这样呢,就可以保证三角形的形状不会发生变化,
//换句话说,就是从上往下看,前一行的每一行的数,正下方都会有一个数// 如果去掉转义字符,改为空格,即:System.out.print(arr[i][j]+" \t");
// 则运行后如下
// 1
// 1 1
// 1 2 1
// 1 3 3 1
// 1 4 6 4 1
// 1 5 10 10 5 1
}
System.out.println();
}
}
}