究极水题—模拟
至于我为什么要写一个水题的题解,看我一一给你道来
题目描述
美国总统奥巴马不仅呼吁所有人都学习编程,甚至以身作则编写代码,成为美国历史上首位编写计算机代码的总统。
2014年底,为庆祝“计算机科学教育周”正式启动,奥巴马编写了很简单的计算机代码:在屏幕上画一个正方形。现在你也跟他一起画吧!
输入
多组输入,每组数据一行,每行给出正方形边长N(3<=N<=20)和组成正方形边的某种字符C,间隔一个空格。
输出
输出由给定字符C画出的正方形。但是注意到行间距比列间距大,所以为了让结果看上去更像正方形,我们输出的行数实际上是列数的50%(四舍五入取整)。
每组数据后空一行
样例输入
10 a
样例输出
aaaaaaaaaa
a a
a a
a a
aaaaaaaaaa
ps:
简单模拟即可,按照题目要求来一遍,这个题目陷阱很多输入的时候,要先输入数字,空格,字符,因为空格也是一个字符,所以用喜欢用cin,cout的同学要注意了,可以用字符串代替,输入的时候只需要输入首字母就行,这样就避免了空格作怪,喜欢用scanf,printf的同学在输入的时候要注意中间要空一个空格。
另一个陷阱就是在每行输出的时候都要换行,每组数据之间又要换行,简而言之,就是末尾换两行,其余换一行。
首先贴上我并不完美的题解
#include <bits/stdc++.h>
using namespace std;
int ans[10005];
int main()
{
int n, m;
char c;
while (~scanf("%d %c", &n, &c))
{
if (n & 1)
m = n / 2 + 1;
else
m = n / 2;
for (int i = 1; i <= m; ++i)
{
if (i == 1 || i == m)
{
for (int j = 1; j <= n; ++j)
printf("%c", c);
}
else
{
for (int j = 1; j <= n; ++j)
if (j == 1 || j == n)
printf("%c", c);
else
printf(" ");
}
printf("\n");
}
printf("\n");
}
return 0;
}
下面贴上大佬的题解
大佬的题解有许多可取之处,首先就是四舍五入的简便方法,只需要对一个数先加一再除以2!!其次便是用字符串获取首字母(这个方法非常的好,在其他题目中,经常会要我们判断字符串,大部分情况下我们只需要判断首字母即可,这不仅大大缩短时间,也极其的精简代码)。
大佬的代码需要细细品味,真的很好~
#include <bits/stdc++.h>
#define endl '\n'
using namespace std;
const int maxn = 1e3 + 5;
int n;
char s[10];
int main()
{
while (cin >> n >> s)
{
int m = (n + 1) / 2;
for (int i = 0; i < m; i++)
{
for (int j = 0; j < n; j++)
{
if (i == 0 || i == m - 1 || j == 0 || j == n - 1)
cout << s[0];
else
cout << " ";
}
cout << endl;
}
cout << endl;
}
return 0;
}
另一个大佬的题解
这个大佬用的是putchar输出,我觉得有必要普及一下它的用法
putchar()函数的作用:向终端输出一个字符。
putchar()函数只能用于单个字符的输出,且一次只能输出一个字符。另外,从功能角度来看,printf()函数可以完全代替putchar()函数。
putchar函数的基本格式为:putchar(c)。
(1)当c为一个被单引号(英文状态下)引起来的字符时,输出该字符(注:该字符也可为转义字符);
putchar('c')------->c
(2)当c为一个介于0~127(包括0及127)之间的十进制整型数时,它会被视为对应字符的ASCII代码,输出该ASCII代码对应的字符;
putchar(97)-------->a
(3)当c为一个事先用char定义好的字符型变量时,输出该变量所指向的字符。
char c='a'
putchar(c)-------->a
就直接按照样例输出即可
#include <bits/stdc++.h>
using namespace std;
int main()
{
int n;
char c;
while (~scanf("%d %c", &n, &c))
{
int col = (n + 1) / 2; //四舍五入
int row = n;
for (int j = 1; j <= row; ++j)
putchar(c);
putchar('\n');
for (int i = 1; i <= col - 2; ++i)
{
putchar(c);
for (int j = 1; j <= row - 2; ++j)
putchar(' ');
putchar(c);
putchar('\n');
}
for (int j = 1; j <= row; ++j)
putchar(c);
printf("\n\n");
}
return 0;
}
爱是一生的难题 。祝少年不老,祝爱情和自尊两全,祝所有想触碰的却又缩回的手,最终都紧紧牵在一起。 |
---|