编程介的小学生 2017-11-09 11:42 采纳率: 20.5%
浏览 752

叠筐

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@
@@@

  • 写回答

1条回答 默认 最新

  • xiyu_dang 2018-01-04 09:23
    关注

    #include

    using namespace std;

    int main()
    {
    int n;
    char a, s, t;
    char st[100][100];
    while(~scanf("%d %c %c",&n,&a,&s))
    {
    if(n == 1)
    printf("%c\n",a);
    else
    {
    int l = 0,k,w = n - 1;
    if((n-1) % 4 == 0)
    {
    t = s;
    s = a;
    a = t;
    }
    for(int i = 0,j = n - 1; i <= j; i++,j--)
    {
    for(k = i; k <= j; k++)
    {
    if(l % 2 == 0)
    st[i][k] = st[j][k] = st[k][i] = st[k][j] = s;
    else
    st[i][k] = st[j][k] = st[k][i] = st[k][j] = a;
    }
    l++;
    }

            st[0][w] = st[w][0] = st[0][0] = st[w][w] = ' ';
            for(int i = 0; i < n; i++)
            {
                for(int j = 0; j < n ; j++)
                    printf("%c",st[i][j]);
                printf("\n");
            }
        }
        printf("\n");
    }
    return 0;
    

    }

    评论

报告相同问题?

悬赏问题

  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?