王道机试 例题2.5 叠筐

王道机试 例题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)即可;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值