本题目要求你在控制台输出一个由数字组成的等腰三角形。
具体的步骤是:
1. 先用1,2,3,...的自然数拼一个足够长的串
2. 用这个串填充三角形的三条边。从上方顶点开始,逆时针填充。
比如,当三角形高度是8时:
1
2 1
3 8
4 1
5 7
6 1
7 6
891011121314151
输入,一个正整数n(3<n<300),表示三角形的高度
输出,用数字填充的等腰三角形。
为了便于测评,我们要求空格一律用"."代替。
例如:
输入:
5
程序应该输出:
....1
...2.1
..3...2
.4.....1
567891011
再例如:
输入:
10
程序应该输出:
.........1
........2.2
.......3...2
......4.....2
.....5.......1
....6.........2
...7...........0
..8.............2
.9...............9
1011121314151617181
再例如:
输入:
15
程序应该输出:
..............1
.............2.3
............3...2
...........4.....3
..........5.......1
.........6.........3
........7...........0
.......8.............3
......9...............9
.....1.................2
....0...................8
...1.....................2
..1.......................7
.1.........................2
21314151617181920212223242526
资源约定:
峰值内存消耗(含虚拟机) < 256M
CPU消耗 < 1000ms
通过对题目给出的测试样例得知,
列宽=行高*2-1;
循环终点的数字是n*2+3; 【n是行高】
先将数组全部初始化成“."; 对等腰三角形进行分割打印,先打印左边、底边、右边
public static void main(String[] args) {
Scanner scanner=new Scanner(System.in);
//输入行数
int n=scanner.nextInt();
//列宽=行高*2-1;
int m=n*2-1;
String str[][]=new String[n][m];
int i,j;
for(i=0;i<n;i++)
for(j=0;j<m;j++)
str[i][j]=".";
int Max=n*2+3;//循环终点的数字就是n*2+3;
String string="";
for( i=1;i<=Max;i++)
string+=i+"";
int count=0;
//等腰三角形的左边
for(i=0;i<n;i++)
str[i][m/2-i]=string.charAt(count++)+"";
//等腰三角形的底边
for(i=1;i<m;i++)
str[n-1][i]=string.charAt(count++)+"";
int a=1;
//等腰三角形的右边
for(i=n-2;i>=1;i--)
str[i][m-1-a++]=string.charAt(count++)+"";
for(i=0;i<n;i++) {
for(j=0;j<m;j++)
System.out.print(str[i][j]);
System.out.println();
}
}