蓝桥杯 打印十字图 Java
问题描述
小明为某机构设计了一个十字型的徽标(并非红十字会啊),如下所示:
对方同时也需要在电脑dos窗口中以字符的形式输出该标志,并能任意控制层数。
输入格式
一个正整数 n (n<30) 表示要求打印图形的层数。
输出格式
对应包围层数的该标志。
样例输入1
1
样例输出1
样例输入2
3
样例输出2
提示
请仔细观察样例,尤其要注意句点的数量和输出位置。
思路:
可以把红色数字分为几部分来找规律:(红色代表$,黑色代表 . )
如图:
找完第二象限的规律后,再根据对称性推出其他三个象限的"$","."即可。
源代码
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
//System.out.print( 4*n+5);
// char[][] array = new char[4*n+5][4*n+5];
for (int i = 1; i <=4*n+5 ; i++) {
for (int j = 1; j <= 4*n+5; j++) {
//System.out.print(111);
if (go(i,j,n) == 1) {
System.out.print("$");
}else {
System.out.print(".");
}
}
System.out.println();
}
}
public static int go(int i, int j, int n) {
// TODO Auto-generated method stub
//上下对称
if (i - 1 > (n*4+5)/2) {
i = i - (i - ((n*4+5)/2 + 1))*2;
}
// 左右对称
if (j - 1 > (n*4+5)/2) {
j = j - (j - ((n*4+5)/2 + 1))*2;
}
if (i%2 == 0 && j >= i+1) {
if (i > 1 && j == i+1 && i%2 == 0) return 1;
else return 0;
}
if (i > 1 && j == i+1 && i%2 == 1) return 0;
// 前面两行.
if (i <= 2 && j <= 2) return 0;
// 连续三个$
if (i%2 == 1 && j >= i-2) return 1;
// $
if (j%2 == 1 && j != i-1) return 1;
return 0;
}
}
注:该源码参考于其他文章