实现根据最大数位数来打印杨辉三角,数字自动对齐。
把数字转变为固定长度的字符串从而使杨辉三角不变形。
public static String Change(int a,int b){ //根据位数进行对齐操作
String S = "";
int c = Integer.toString(a).length();
int i = 0;
for(i = 0;i<b;){
if(i == (b-c)/2){
S = S+Integer.toString(a);
i = i+ c;
}
else{
S = S +" ";
i++;
}
}
return S;
}
public static void main(String[] args) {
// TODO 自动生成的方法存根
System.out.println("请输入行数");
Scanner row=new Scanner(System.in);
int n=row.nextInt();
String s = new String();
int arr[][]=new int[n][2*n+1];
for(int i=0;i<n;i++){
arr[i][n-i]=1;
arr[i][n+i]=1;
}
for(int i=1;i<n;i++){
for(int j=1;j<=2*n-1;j++) {
arr[i][j]=arr[i-1][j+1]+arr[i-1][j-1];
}
}
int weishu = Integer.toString(arr[n-1][n-n%2-1]).length();
int k = 0;
for(int i=0;i<arr.length;i++){
for(int j=0;j<=arr.length+i;j++){
if(arr[i][j] == 0){
for(k=0;k<weishu;k++){
System.out.print(" ");
}
}
else{
s=Change(arr[i][j],weishu );
System.out.print(s);
}
}
System.out.println();
}
row.close();
}