先言:
杨辉三角已经在先前实现过了,但对Java的二维数组的传值、内存分配不甚理解。因此,做该题练练手,也”不辜负“我对它的厚望,成功的又冒出几个问题。
代码演示:
package test_2032;
//实现杨辉三角的打印
//每个数之间用空格隔开
//每个杨辉三角之间空一行
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
while(sc.hasNext()){
//要在循环体里创建变量n 对其录入
/*
* 不然嘞,没有理解错的话
* 在console录入的会是两个数,且会死循环输出杨辉三角@_@
*/
int n = sc.nextInt();
// while(sc.hasNext()){
//创建一个二维数组,行列均为n
int[][] arr = new int[n][n];
for(int i = 0;i < arr.length;i++) {
arr[i][0] = 1;//控制第一列第一行为一
arr[i][i] = 1;//控制每行最后一个均为一
}
//从第三行开始
for(int i = 2;i < arr.length;i++) {
//从第二个元素开始
//这边要考虑一下最后一行是i-1,即j <= i-1;或者j < i;
for(int j = 1;j < i;j++){
arr[i][j] = arr[i-1][j-1] + arr[i-1][j];
}
}
//遍历该二维数组
for(int i = 0; i < arr.length; i++) {
/*
* 内循环的限定条件应该 j < i 呈现 正三角形
* 而不是arr[i].length
*/
for(int j = 0;j < i; j++) {
//制表符无法实现
System.out.print(arr[i][j]+" ");
}
System.out.println(arr[i][i]);
}
System.out.println();
}//while
}//main
}
部分问题在代码的注释中已经说明了。
分析:
题目要求是(1<n<30),而且数字间空格为一。
但当n>=10,已经有数据为三位数了,这说明了你打印出来的杨辉三角不会每一个整数上下整齐对应的,每个数据间只空一格且上下对其的可行性为0。综上,优先排除使用制表符的可能性。即,满足每个数据间是空格间隔开即可。但,注意最后一个数据“外壳”1,其后面不要也顺手加一个空格。即,在内循环遍历最后单独打印出来。
效果演示: