分析:这道题一开始是真的懵,什么十字图???然后去网上找了下,看见有人画了出来。
然后就知道怎么做了。考蓝桥杯的时候还要会画图。不过我觉得原作者的代码太过复杂,填写$符号的位置完全可以一遍遍历搞定,方便点。
思路是这是一个上下左右对称图形,我们得到黑色框框出来的部分就可以输出整个图形。先设置所有背景为'.',然后将黑色斜线框出来的'$'部分都找到,再填充它的行列中的'$'部分。
#include<iostream>
#include<string>
#include<vector>
#include<algorithm>
using namespace std;
int main()
{
int n,row;
cin>>n;
row=(2*n)*2+5;//总行列数目
string a[68];
for(int i=0;i<(row+1)/2;i++)
{
a[0]+=".";
}
for(int i=1;i<(row+1)/2;i++)
{
a[i]=a[0];
}
for(int i=0;i<(row-3)/2;i=i+2)
{
for(int j=i+2;j<(row+1)/2;j++)
{
a[i][j]='$';//A部分的'$'
a[j][i]='$';//C部分的'$'
}
//B部分的'$'
a[i+1][i+2]='$';
a[i+2][i+2]='$';
a[i+2][i+1]='$';
}
for(int i=0;i<(row+1)/2;i++)//左右翻转
{
string helpa;
helpa=a[i];
reverse(helpa.begin(), helpa.end());
a[i].erase(a[i].end()-1);
a[i]+=helpa;
cout<<a[i]<<endl;
}
for(int i=2*n+1;i>=0;i--)//上下逆序输出
{
cout<<a[i]<<endl;
}
return 0;
}