打印大X
小明希望用星号拼凑,打印出一个大X,他要求能够控制笔画的宽度和整个字的高度。
为了便于比对空格,所有的空白位置都以句点符来代替。
为了便于比对空格,所有的空白位置都以句点符来代替。
要求输入两个整数m n,表示笔的宽度,X的高度。用空格分开(0<m<n, 3<n<1000, 保证n是奇数)
要求输出一个大X
要求输出一个大X
例如,用户输入:
3 9
程序应该输出:
***.....***
.***...***.
..***.***..
...*****...
....***....
...*****...
..***.***..
.***...***.
***.....***
3 9
程序应该输出:
***.....***
.***...***.
..***.***..
...*****...
....***....
...*****...
..***.***..
.***...***.
***.....***
(如有对齐问题,参看【图1.jpg】)
再例如,用户输入:
4 21
程序应该输出
****................****
.****..............****.
..****............****..
...****..........****...
....****........****....
.....****......****.....
......****....****......
.......****..****.......
........********........
.........******.........
..........****..........
.........******.........
........********........
.......****..****.......
......****....****......
.....****......****.....
....****........****....
...****..........****...
..****............****..
.****..............****.
****................****
4 21
程序应该输出
****................****
.****..............****.
..****............****..
...****..........****...
....****........****....
.....****......****.....
......****....****......
.......****..****.......
........********........
.........******.........
..........****..........
.........******.........
........********........
.......****..****.......
......****....****......
.....****......****.....
....****........****....
...****..........****...
..****............****..
.****..............****.
****................****
分析:通过样例可以看出规律:以笔的宽度,每移动一行就往右走一列,直到到达n行。列的个数即:col = n - 1+ w;(第一行没留空),上代码:
import java.util.*;
public class Main{
static Scanner sc = new Scanner(System.in);
static int m,n;
static int [][] map;
public static void main(String[] args) {
m = sc.nextInt(); n = sc.nextInt();
int c = n-1+m;
map = new int[n][c];
for(int i = 0; i < n; i++) {
for(int j = i; j < i+m; j++) {//主对角线的
map[i][j] = 1;//置1表示画*的
} // 0 1 2 3 4
for(int j = c-i-1; j > c-i-1-m; j--) {//副对角线的
map[i][j] = 1;
}
}
for(int i = 0; i < n; i++) {
for(int j = 0; j < c; j++) {
System.out.print(map[i][j]==1?"*":".");
}
System.out.println();
}
}
}
对角线的
map[i][j] = 1;
}
}
for(int i = 0; i < n; i++) {
for(int j = 0; j < c; j++) {
System.out.print(map[i][j]==1?"*":".");
}
System.out.println();
}
}
}
反思:寻找符号规律,行列关系即可