历届试题 打印十字图
时间限制:1.0s 内存限制:256.0MB
问题描述
小明为某机构设计了一个十字型的徽标(并非红十字会啊),如下所示:
..$$$$$$$$$$$$$..
..$...........$..
$$$.$$$$$$$$$.$$$
$...$.......$...$
$.$$$.$$$$$.$$$.$
$.$...$...$...$.$
$.$.$$$.$.$$$.$.$
$.$.$...$...$.$.$
$.$.$.$$$$$.$.$.$
$.$.$...$...$.$.$
$.$.$$$.$.$$$.$.$
$.$...$...$...$.$
$.$$$.$$$$$.$$$.$
$...$.......$...$
$$$.$$$$$$$$$.$$$
..$...........$..
..$$$$$$$$$$$$$..
对方同时也需要在电脑dos窗口中以字符的形式输出该标志,并能任意控制层数。
输入格式
一个正整数 n (n<30) 表示要求打印图形的层数。
输出格式
对应包围层数的该标志。
样例输入1
1
样例输出1
..$$$$$..
..$...$..
$$$.$.$$$
$...$...$
$.$$$$$.$
$...$...$
$$$.$.$$$
..$...$..
..$$$$$..
样例输入2
3
样例输出2
..$$$$$$$$$$$$$..
..$...........$..
$$$.$$$$$$$$$.$$$
$...$.......$...$
$.$$$.$$$$$.$$$.$
$.$...$...$...$.$
$.$.$$$.$.$$$.$.$
$.$.$...$...$.$.$
$.$.$.$$$$$.$.$.$
$.$.$...$...$.$.$
$.$.$$$.$.$$$.$.$
$.$...$...$...$.$
$.$$$.$$$$$.$$$.$
$...$.......$...$
$$$.$$$$$$$$$.$$$
..$...........$..
..$$$$$$$$$$$$$..
提示
请仔细观察样例,尤其要注意句点的数量和输出位置。
小明为某机构设计了一个十字型的徽标(并非红十字会啊),如下所示:
..$$$$$$$$$$$$$..
..$...........$..
$$$.$$$$$$$$$.$$$
$...$.......$...$
$.$$$.$$$$$.$$$.$
$.$...$...$...$.$
$.$.$$$.$.$$$.$.$
$.$.$...$...$.$.$
$.$.$.$$$$$.$.$.$
$.$.$...$...$.$.$
$.$.$$$.$.$$$.$.$
$.$...$...$...$.$
$.$$$.$$$$$.$$$.$
$...$.......$...$
$$$.$$$$$$$$$.$$$
..$...........$..
..$$$$$$$$$$$$$..
对方同时也需要在电脑dos窗口中以字符的形式输出该标志,并能任意控制层数。
输入格式
一个正整数 n (n<30) 表示要求打印图形的层数。
输出格式
对应包围层数的该标志。
样例输入1
1
样例输出1
..$$$$$..
..$...$..
$$$.$.$$$
$...$...$
$.$$$$$.$
$...$...$
$$$.$.$$$
..$...$..
..$$$$$..
样例输入2
3
样例输出2
..$$$$$$$$$$$$$..
..$...........$..
$$$.$$$$$$$$$.$$$
$...$.......$...$
$.$$$.$$$$$.$$$.$
$.$...$...$...$.$
$.$.$$$.$.$$$.$.$
$.$.$...$...$.$.$
$.$.$.$$$$$.$.$.$
$.$.$...$...$.$.$
$.$.$$$.$.$$$.$.$
$.$...$...$...$.$
$.$$$.$$$$$.$$$.$
$...$.......$...$
$$$.$$$$$$$$$.$$$
..$...........$..
..$$$$$$$$$$$$$..
提示
请仔细观察样例,尤其要注意句点的数量和输出位置。
代码如下:
#include<iostream>
#include<cmath>
#include<string>
using namespace std;
int main()
{
int n,A[200][200]={0};
cin>>n;
int x0=2*n+2,y0=2*n+2;
for(int i=0;i<=n;i++)
{
for(int j=0;j<4*i+1;j++)
A[x0-2*(i+1)][y0-2*i+j]=1;
for(int j=0;j<4*i+1;j++)
A[x0+2*(i+1)][y0-2*i+j]=1;
for(int j=0;j<4*i+1;j++)
A[x0-2*i+j][y0-2*(i+1)]=1;
for(int j=0;j<4*i+1;j++)
A[x0-2*i+j][y0+2*(i+1)]=1;
A[x0-2*(i+1)+1][y0-2*i]=1;A[x0-2*(i+1)+2][y0-2*i]=1;
A[x0+2*(i+1)-1][y0-2*i]=1;A[x0+2*(i+1)-2][y0-2*i]=1;
A[x0+2*(i+1)-2][y0-2*i-1]=1;
A[x0-2*(i+1)+2][y0-2*i-1]=1;
A[x0-2*(i+1)+1][y0+2*i]=1;A[x0-2*(i+1)+2][y0+2*i]=1;
A[x0+2*(i+1)-1][y0+2*i]=1;A[x0+2*(i+1)-2][y0+2*i]=1;
A[x0+2*(i+1)-2][y0+2*i+1]=1;
A[x0-2*(i+1)+2][y0+2*i+1]=1;
}
for(int k=0;k<4*(n+1)+1;k++)
{
for(int p=0;p<4*(n+1)+1;p++)
{
if(A[k][p]==0)
cout<<".";
else
cout<<"$";
}
cout<<endl;
}
return 0;
}