蓝桥杯:打印十字图
题目描述:
小明为某机构设计了一个十字型的徽标(并非红十字会啊),如下所示:
对方同时也需要在电脑dos窗口中以字符的形式输出该标志,并能任意控制层数。
输入格式
一个正整数 n (n<30) 表示要求打印图形的层数。
输出格式
对应包围层数的该标志。
输入样例1:
输入:1
输出:
输入样例2:
输入:3
输出:
代码:
#include<iostream>
#include<stdio.h>
using namespace std;
char arr[9+4*28][9+4*28];
int N,L=0,R;
void printAll(int l,int r)
{
for(int i=l;i<=r;i++)
{
for(int j=l;j<=r;j++)
{
if(arr[i][j]!='$')
arr[i][j]='.';
cout<<arr[i][j];
}
cout<<endl;
}
}
void dealN(int n)
{
int l=2*(N-n),r=R-l;//可以取到最大最小下标
//处理第一行和最后一行
for(int i=l+2;i<=r-2;i++)
{
arr[l][i]='$';
arr[r][i]='$';
}
//处理第二行和倒数第二行
arr[l+1][l+2]='$';
arr[l+1][r-2]='$';
arr[r-1][l+2]='$';
arr[r-1][r-2]='$';
//处理第三行和倒数第三行
arr[l+2][l+0]='$';
arr[l+2][l+1]='$';
arr[l+2][l+2]='$';
arr[l+2][r]='$';
arr[l+2][r-1]='$';
arr[l+2][r-2]='$';
arr[r-2][l+0]='$';
arr[r-2][l+1]='$';
arr[r-2][l+2]='$';
arr[r-2][r]='$';
arr[r-2][r-1]='$';
arr[r-2][r-2]='$';
//处理两边
for(int j=l+3;j<=r-3;j++)
{
arr[j][l]='$';
arr[j][r]='$';
}
}
int main()
{
scanf("%d",&N);
R=9+4*(N-1)-1;
for(int i=N;i>=1;i--)
{
dealN(i);
}
//十字的行列
for(int j=2*N;j<2*N+5;j++)
{
arr[2*N+2][j]='$';
arr[j][2*N+2]='$';
}
printAll(0,9+4*(N-1)-1);
return 0;
}