问题描述
小明为某机构设计了一个十字型的徽标(并非红十字会啊),如下所示:
..
.
$.
...
$.
.
$.$.
.
.
$.$.
.
.
$.
.
$.
$.
..
...........
....
对方同时也需要在电脑dos窗口中以字符的形式输出该标志,并能任意控制层数。
输入格式
一个正整数 n (n<30) 表示要求打印图形的层数。
输出格式
对应包围层数的该标志。
样例输入1
1
样例输出1
..
.$.
....
$.$.
..
...
....
样例输入2
3
样例输出2
..
.
$.
...
$.
.
$.$.
.
.
$.$.
.
.
$.
.
$.
$.
..
...........
....
提示
请仔细观察样例,尤其要注意句点的数量和输出位置。
仔细观察,发现行数 列数与n的关系是4*n+5
通过分析样例,发现奇数行中行数大于行数减去2的打印 ,奇数列中列数不等于行数减去1的打印 。上代码
package cn.lml.lanqiao.www;
import java.util.*;
public class LanQiao {
/**
* @param args
*/
//找规律,实在是无技术,规律难找,找了也不好写,2017年1月21日
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner s=new Scanner (System.in);
int n=s.nextInt();
for(int i=1;i<=n*4+5;i++){
for(int j=1;j<=n*4+5;j++){
if(f(i,j,n)){
System.out.print("$");
}
else
System.out.print(".");
}
System.out.println();
}
}
private static boolean f(int i, int j, int n) {
// TODO Auto-generated method stub
/*
* 下面考虑如何打印所有部分/
*/
if(i>2*n+3){//考虑上下两部分
i=n*4+6-i;
}
if(j>2*n+3){
j=n*4+6-j;
}
if(j>i){
i^=j;
j^=i;
i^=j;
}
/*
* 下面打印的是左上部分/
*/
if(i<=2&&j<=2)return false;
if(i%2==1&&j>i-2)return true;//奇数行且列数比行数减去2大,就打印$
if(j%2==1&&j!=i-1)return true;//奇数列且列数不等于行数减去1,就打印.
return false;
}
}