java:打印十字图
题目
问题描述
小明为某机构设计了一个十字型的徽标(并非红十字会啊),如下所示:
..$$$$$$$$$$$$$..
..$...........$..
$$$.$$$$$$$$$.$$$
$...$.......$...$
$.$$$.$$$$$.$$$.$
$.$...$...$...$.$
$.$.$$$.$.$$$.$.$
$.$.$...$...$.$.$
$.$.$.$$$$$.$.$.$
$.$.$...$...$.$.$
$.$.$$$.$.$$$.$.$
$.$...$...$...$.$
$.$$$.$$$$$.$$$.$
$...$.......$...$
$$$.$$$$$$$$$.$$$
..$...........$..
..$$$$$$$$$$$$$..
对方同时也需要在电脑dos窗口中以字符的形式输出该标志,并能任意控制层数。
输入格式
一个正整数 n (n<30) 表示要求打印图形的层数。
输出格式
对应包围层数的该标志。
样例输入1
1
样例输出1
..$$$$$..
..$...$..
$$$.$.$$$
$...$...$
$.$$$$$.$
$...$...$
$$$.$.$$$
..$...$..
..$$$$$..
样例输入2
3
样例输出2
..$$$$$$$$$$$$$..
..$...........$..
$$$.$$$$$$$$$.$$$
$...$.......$...$
$.$$$.$$$$$.$$$.$
$.$...$...$...$.$
$.$.$$$.$.$$$.$.$
$.$.$...$...$.$.$
$.$.$.$$$$$.$.$.$
$.$.$...$...$.$.$
$.$.$$$.$.$$$.$.$
$.$...$...$...$.$
$.$$$.$$$$$.$$$.$
$...$.......$...$
$$$.$$$$$$$$$.$$$
..$...........$..
..$$$$$$$$$$$$$..
提示
请仔细观察样例,尤其要注意句点的数量和输出位置。
分析
https://blog.csdn.net/jopus/article/details/19091643
既然我们找到了它的一些思路,我们再来找一些他们的关系
其实我的思路是,我先把最中间的十字打印出来,之后再打印外层,外层基本上就是一样的模型,一层层进行扩大的,这样是不是就可以利用递归的方法
…$$$KaTeX parse error: Can't use function '$' in math mode at position 6: .. ..$̲...$.. .$KaTeX parse error: Can't use function '$' in math mode at position 2: $̲...$...$ $.$KaTeX parse error: Can't use function '$' in math mode at position 2: .$̲ $...$...$ .$KaTeX parse error: Can't use function '$' in math mode at position 4: ..$̲...$.. ..$$$…
也可以先打印中间的十,再打印旁边的点,在打印旁边的十
我觉得那后面还是变为分为三个部分打印这个图形
长为:5+4n
宽为:5+4n
# java:打印十字图
## 题目
```java
问题描述
小明为某机构设计了一个十字型的徽标(并非红十字会啊),如下所示:
..$$$$$$$$$$$$$..
..$...........$..
$$$.$$$$$$$$$.$$$
$...$.......$...$
$.$$$.$$$$$.$$$.$
$.$...$...$...$.$
$.$.$$$.$.$$$.$.$
$.$.$...$...$.$.$
$.$.$.$$$$$.$.$.$
$.$.$...$...$.$.$
$.$.$$$.$.$$$.$.$
$.$...$...$...$.$
$.$$$.$$$$$.$$$.$
$...$.......$...$
$$$.$$$$$$$$$.$$$
..$...........$..
..$$$$$$$$$$$$$..
对方同时也需要在电脑dos窗口中以字符的形式输出该标志,并能任意控制层数。
输入格式
一个正整数 n (n<30) 表示要求打印图形的层数。
输出格式
对应包围层数的该标志。
样例输入1
1
样例输出1
..$$$$$..
..$...$..
$$$.$.$$$
$...$...$
$.$$$$$.$
$...$...$
$$$.$.$$$
..$...$..
..$$$$$..
样例输入2
3
样例输出2
..$$$$$$$$$$$$$..
..$...........$..
$$$.$$$$$$$$$.$$$
$...$.......$...$
$.$$$.$$$$$.$$$.$
$.$...$...$...$.$
$.$.$$$.$.$$$.$.$
$.$.$...$...$.$.$
$.$.$.$$$$$.$.$.$
$.$.$...$...$.$.$
$.$.$$$.$.$$$.$.$
$.$...$...$...$.$
$.$$$.$$$$$.$$$.$
$...$.......$...$
$$$.$$$$$$$$$.$$$
..$...........$..
..$$$$$$$$$$$$$..
提示
请仔细观察样例,尤其要注意句点的数量和输出位置。
分析
https://blog.csdn.net/jopus/article/details/19091643
既然我们找到了它的一些思路,我们再来找一些他们的关系
其实我的思路是,我先把最中间的十字打印出来,之后再打印外层,外层基本上就是一样的模型,一层层进行扩大的,这样是不是就可以利用递归的方法
…$$$KaTeX parse error: Can't use function '$' in math mode at position 6: .. ..$̲...$.. .$KaTeX parse error: Can't use function '$' in math mode at position 2: $̲...$...$ $.$KaTeX parse error: Can't use function '$' in math mode at position 2: .$̲ $...$...$ .$KaTeX parse error: Can't use function '$' in math mode at position 4: ..$̲...$.. ..$$$…
也可以先打印中间的十,再打印旁边的点,在打印旁边的十
我觉得那后面还是变为分为三个部分打印这个图形
长为:5+4n
宽为:5+4n
代码
import java.util.Scanner;
public class 打印十字图 {
public static void getResult(int n){
int len=5+4*n;//长和宽都是这个长度
int mid=len/2;//中间的数据,9/2=4
char[][] arr=new char[len][len];//长宽都一样,对称的
//先初始化图形
for(int i=0;i<len;i++)
for(int j=0;j<len;j++)
arr[i][j]='.';//将图形初始化都为.
//把中间的十字写出来
for(int i=mid-2;i<=mid+2;i++){//记住他们都是从0开始的
arr[mid][i]='$';//这个用了一个很巧的方法,先写的是竖着的
arr[i][mid]='$';//数组里面的可以覆盖原来的值
}
for(int i=1;i<=n;i++){
for(int j=mid-2*i;j<=mid+2*i;j++){
arr[mid-2*(i+1)][j]='$';//外框竖
arr[mid+2*(i+1)][j]='$';//外框右边的$
arr[j][mid-2*(i+1)]='$';//外框高的$
arr[j][mid+2*(i+1)]='$';//外框第的&
}
//左上角
arr[mid-2*i][mid-2*i]='$';
arr[mid-2*i-1][mid-2*i]='$';
arr[mid-2*i][mid-2*i-1]='$';
//右上角
arr[mid+2*i][mid-2*i]='$';
arr[mid+2*i+1][mid-2*i]='$';
arr[mid+2*i][mid-2*i-1]='$';
//右下角
arr[mid+2*i][mid+2*i]='$';
arr[mid+2*i+1][mid+2*i]='$';
arr[mid+2*i][mid+2*i+1]='$';
//左下角
arr[mid-2*i][mid+2*i]='$';
arr[mid-2*i-1][mid+2*i]='$';
arr[mid-2*i][mid+2*i+1]='$';
}
for(int i=0;i<len;i++){
for(int j=0;j<len;j++){
System.out.print(arr[i][j]);
}
System.out.println();
}
}
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner sc=new Scanner(System.in);
int n=sc.nextInt();
getResult(n);
}
}