打印十字图
问题描述
小明为某机构设计了一个十字型的徽标(并非红十字会啊),如下所示:
,并能任意控制层数。
输入格式
一个正整数 n (n<30) 表示要求打印图形的层数。
输出格式
对应包围层数的该标志。
样例输入1
1
样例输出1
样例输入2
3
样例输出2
分析:通过观察会发现这个图形时中心对称的图形,还会发现其实’.'和‘$‘是一样的,n的值也为外框框的层数,再利用对’$‘和’.'开始位置分析和结束位置分析就可以发现规律。看下图👇
代码:
#include<iostream>
#include<windows.h>
using namespace std;
char data[300][300];//保存数据
void test(int n,int len,char c){
for(int i=n;i<len;i++){
for(int j=n+2;j<len-2;j++){
data[i][j]=c;
}
for(int j=2+n;j<len-2;j++){
data[j][i]=c;
}
}
}
int main(){
int n;
cin>>n;
int w=9+(n-1)*4;
for(int i=0;i<w;i++){
for(int j=0;j<w;j++){
data[i][j]='.';
}
}
//通过规律知道n就是红十字的外层层数,先把外层打出来
for(int i=0;i<n;i++){
test(2*i,w-2*i,'$');
test(2*i+1,w-2*i-1,'.');
}
//构建中间的十字架
int middle=w/2;//
for(int i=middle-2;i<=middle+2;i++){
data[middle][i]='$';
}
for(int i=middle-2;i<=middle+2;i++){
data[i][middle]='$';
}
//打印输出
for(int i=0;i<w;i++){
for(int j=0;j<w;j++){
cout<<data[i][j];
}
cout<<endl;
}
//system("pause");暂停观察结果
return 0;
}
总结:①:通过一个个小的形状再去联系到整个图形的整体构造
②:在该题中还可以考虑到对称的下标进行复制(因为该图形是中心对称的图形,算出整体图形的1/4就行了。