Borges


私信TA

用户名:010915

访问量:743

签 名:

等  级
排  名 53519
经  验 262
参赛次数 0
文章发表 1
年  龄 18
在职情况 学生
学  校
专  业 计算机科学与技术

  自我简介:

解题思路:先写上半部分,再写上半部分,分析符号位置,找出符号数量和行数的规律。

参考代码:

#include<stdio.h>

int main() {

    int i, j, n, m;

    scanf("%d%d", &m, &n);

    int width = m + n / 2 * 2;

    for (i = 1; i <= n / 2; i++) {

        for (j = 0; j < i - 1; j++)

            printf(".");

        for (j = 0; j < m; j++)

            printf("*");

        for (j = 0; j < width - m * 2 - (i - 1) * 2; j++)

            printf(".");

        if ((width - m * 2 - (i - 1) * 2) <= 0) {

            for (j = 0; j < width - m - (i - 1) * 2; j++)

                printf("*");

        }

        else {

        for (j = 0; j < m; j++)

                printf("*");

        }

        for (j = 0; j < i - 1; j++)

                printf(".");

        printf("\n");

    }

    for (i = 1; i <= n / 2 + 1; i++) {

        for (j = 0; j < (width - m) / 2 - i + 1; j++)

                printf(".");

        for (j = 0; j < m; j++)

                printf("*");

        for (j = 0; j < width - m * 2 - ((width - m) / 2 - i + 1) * 2; j++)

                printf(".");

        if ((width - m * 2 - ((width - m) / 2 - i + 1) * 2) <= 0) {

                for (j = 0; j < width - m - ((width - m) / 2 - i + 1) * 2; j++)

                        printf("*");

        }

        else {

                for (j = 0; j < m; j++)

                        printf("*");

        }

        for (j = 0; j < (width - m) / 2 - i + 1; j++)

                printf(".");

        printf("\n");

    }

    return 0;

}


 

0.0分

23 人评分

  评论区

  • «
  • »