王道机试 例题2.5 叠筐
Problem Description
需要的时候,就把一个个大小差一圈的筐叠上去,使得从上往下看时,边筐花色交错。这个工作现在要让计算机来完成,得看你的了。
Input
输入是一个个的三元组,分别是,外筐尺寸n(n为满足0< n<80的奇整数),中心花色字符,外筐花色字符,后二者都为ASCII可见字符;
Output
输出叠在一起的筐图案,中心花色与外筐花色字符从内层起交错相叠,多筐相叠时,最外筐的角总是被打磨掉。叠筐与叠筐之间应有一行间隔。
Sample Input
11 B A
5 @ W
Sample Output
AAAAAAAAA
ABBBBBBBBBA
ABAAAAAAABA
ABABBBBBABA
ABABAAABABA
ABABABABABA
ABABAAABABA
ABABBBBBABA
ABAAAAAAABA
ABBBBBBBBBA
AAAAAAAAA
@@@
@WWW@
@W@W@
@WWW@
@@@
C代码
#include<stdio.h>
char matrix[80][80];
int main()
{
int n; //叠筐尺寸
char z, b; //输入的两个字符
bool firstcase = true; //第一组数据标志,方便不同组之间换行
while (scanf_s("%d%c%c", &n, &z,1, &b,1) != EOF) { //高版本的VS都会让你用scanf_s来替代scanf
//1.可以:Alt + F7,打开工程属性,然后找到图片上标注的地方,添加一行内容_CRT_SECURE_NO_DEPRECATE就OK了
// 2.如果用scanf_s,在读入 % c或者 % s的时候必须多传入一个参数用来指定读取的长度,否则会出错
if (firstcase == true) {
firstcase = false;
}
else {
printf("\n");
}
for (int i = 0; i <= n / 2; i++) { //(i,i)是每一圈左上角的坐标
int j = n - 1 - i; //(j,j)是每一圈右下角的坐标,i+j=n,因为最左上角坐标为(0,0)
int length = n - 2 * i;
char c; //求当前圈的填充字符,通过奇偶性判断
if ((n / 2 - i) % 2 == 0) {
c = z;
}
else {
c = b;
}
for (int k = 0; k < length; ++k) { //为当前圈赋值
matrix[i][i + k] = c; //上边赋值
matrix[i + k][i] = c; //左边赋值
matrix[j][j - k] = c; //下边赋值
matrix[j - k][j] = c; //右边赋值
}
}
if (n !=1 ) { //剔除四个角,n=1是不用剔除
matrix[0][0] = ' ';
matrix[0][n - 1] = ' ';
matrix[n - 1][0] = ' ';
matrix[n - 1][n - 1] = ' ';
}
for (int i = 0; i < n; i++) { //逐行逐列打印
for (int j = 0; j < n; j++) {
printf("%c", matrix[i][j]);
}
printf("\n");
}
}
return 0;
}
# 有个问题
****实际输入时为11BA,中间没有空格,可以正确输出;若按要求输入11 B A会导致‘ ’赋值给z,B赋给b;而且会持续输出多个结果。
这个问题还需要解决一下。****
更新解决。。太菜了,但是还是没想通为什么会持续输出
把scanf_s("%d%c%c", &n, &z,1, &b,1)改为
scanf_s("%d %c %c", &n, &z,1, &b,1)即可;