蒜头君最近迷恋上了一款游戏《我的世界(Minecraft)》,在游戏里面蒜头君可以任意开发资源然后建造各种宏伟的建筑。
有一天蒜头君发现了一块荒野的土地上有很多宝藏,蒜头君想在土地上建一栋房子从而把宝藏包围起来。
假设地图是一个n行m列的方格地图,地图每个格子*代表一个宝藏。比如2行2列的地图如下:
* * * * |
蒜头君对应要建的房子如下:
+- +- + |* |* | +- +- + |* |* | +- +- + |
现在蒜头君告诉你地图的行列数,帮他画出房子的设计图。
输入格式
一行两个整数 n,m(0 < n,m m≤50),分别表示地图行数和列数。
输出格式
按照题目中要求的格式输出地图。
样例输入1
2 2 |
样例输出1
+- +- + |* |* | +- +- + |* |* | +- +- + |
样例输入2
3 4 |
样例输出2
+- +- +- +- + |* |* |* |* | +- +- +- +- + |* |* |* |* | +- +- +- +- + |* |* |* |* | +- +- +- +- + |
分析:
看题目可以知道,这题是根据行列打印相应的图案,在每一行中对于单数双数采用不同打印方式,最后形成图案。
c++代码如下:
#include<iostream>
using namespace std;
int main() {
int x, y;
cin >> x >> y;
for (int i = 1;i <= 2 * x + 1;i++)
{
if (i % 2)
{
for (int j = 1;j <= 2 * y + 1;j++)
{
if (j % 2)
{
cout << "+";
}
else
{
cout << "-";
}
}
cout << endl;
}
else
{
for (int k = 1;k <= 2 * y + 1;k++)
{
if (k % 2)
{
cout << "|";
}
else
{
cout << "*";
}
}
cout << endl;
}
}
}