历届试题 打印十字图

  历届试题 打印十字图  
时间限制:1.0s   内存限制:256.0MB
      
问题描述
小明为某机构设计了一个十字型的徽标(并非红十字会啊),如下所示:
..$$$$$$$$$$$$$..
..$...........$..
$$$.$$$$$$$$$.$$$
$...$.......$...$
$.$$$.$$$$$.$$$.$
$.$...$...$...$.$
$.$.$$$.$.$$$.$.$
$.$.$...$...$.$.$
$.$.$.$$$$$.$.$.$
$.$.$...$...$.$.$
$.$.$$$.$.$$$.$.$
$.$...$...$...$.$
$.$$$.$$$$$.$$$.$
$...$.......$...$
$$$.$$$$$$$$$.$$$
..$...........$..
..$$$$$$$$$$$$$..

对方同时也需要在电脑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;
}


猜你喜欢

转载自blog.csdn.net/tobealistenner/article/details/80610965