标题:打印十字图
小明为某机构设计了一个十字型的徽标(并非红十字会啊)对方同时也需要在电脑dos窗口中以字符的形式输出该标志,并能任意控制层数。为了能准确比对空白的数量,程序要求对行中的空白以句点(.)代替。
输入格式:
一个正整数 n (n<30) 表示要求打印图形的层数
输出:
对应包围层数的该标志。
例如:
用户输入:
1
程序应该输出:
..$$$$$..
..$...$..
$$$.$.$$$
$...$...$
$.$$$$$.$
$...$...$
$$$.$.$$$
..$...$..
..$$$$$..
再例如:
用户输入:
3
程序应该输出:
..$$$$$$$$$$$$$..
..$...........$..
$$$.$$$$$$$$$.$$$
$...$.......$...$
$.$$$.$$$$$.$$$.$
$.$...$...$...$.$
$.$.$$$.$.$$$.$.$
$.$.$...$...$.$.$
$.$.$.$$$$$.$.$.$
$.$.$...$...$.$.$
$.$.$$$.$.$$$.$.$
$.$...$...$...$.$
$.$$$.$$$$$.$$$.$
$...$.......$...$
$$$.$$$$$$$$$.$$$
..$...........$..
..$$$$$$$$$$$$$..
请仔细观察样例,尤其要注意句点的数量和输出位置。
资源约定:
峰值内存消耗(含虚拟机) < 64M
CPU消耗 < 1000ms
请严格按要求输出,不要画蛇添足地打印类似:“请您输入…” 的多余内容。
所有代码放在同一个源文件中,调试通过后,拷贝提交该源码。
注意:不要使用package语句。不要使用jdk1.6及以上版本的特性。
注意:主类的名字必须是:Main,否则按无效代码处理。
import java.util.Scanner;
public class pringten {
public static void fun(int n) {
String a[][] = new String[n*4+5][n*4+5];
int center = n*2+2; //中心点的位置
//首先将其全部初始化为点.
for(int i=0;i<a.length;i++) {
for(int j=0;j<a[i].length;j++)
a[i][j] = ".";
}
//画出最中间的十字架
for(int i=0;i<3;i++) {
a[center-i][center] = "$";
a[center][center-i] = "$";
a[center+i][center] = "$";
a[center][center+i] = "$";
}
//画外边的图案
for(int i=1;i<=n;i++) {
a[center][center-2-(i*2)] = "$";
a[center][center+2+(i*2)] = "$";
for(int j=1;j<=2*i;j++) {
a[center-j][center-2-(i*2)] = "$";
a[center+j][center-2-(i*2)] = "$";
a[center-j][center+2+(i*2)] = "$";
a[center+j][center+2+(i*2)] = "$";
}
a[center-2*i][center-2-(i*2)+1] = "$";
a[center-2*i][center-2-(i*2)+2] = "$";
a[center-2*i][center+2+(i*2)-1] = "$";
a[center-2*i][center+2+(i*2)-2] = "$";
a[center+2*i][center-2-(i*2)+1] = "$";
a[center+2*i][center-2-(i*2)+2] = "$";
a[center+2*i][center+2+(i*2)-1] = "$";
a[center+2*i][center+2+(i*2)-2] = "$";
a[center-2*i-1][center-(i*2)] = "$";
a[center-2*i-2][center-(i*2)] = "$";
a[center+2*i+1][center-(i*2)] = "$";
a[center+2*i+2][center-(i*2)] = "$";
a[center-2*i-1][center+(i*2)] = "$";
a[center-2*i-2][center+(i*2)] = "$";
a[center+2*i+1][center+(i*2)] = "$";
a[center+2*i+2][center+(i*2)] = "$";
for(int k=1;k<=4*i-1;k++) {
a[center-2*i-2][center-(i*2)+k] = "$";
a[center+2*i+2][center-(i*2)+k] = "$";
}
}
//打印输出整个数组
for(int i=0;i<a.length;i++) {
for(int j=0;j<a[i].length;j++) {
System.out.print(a[i][j]);
}
System.out.println(" ");
}
}
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner input = new Scanner(System.in);
int n = input.nextInt();
fun(n);
}
}
}