用*输出边长为n的实心菱形

    输入n,分别用*输出边长为n的实心菱形。

    //    例如:n = 3时,输出:

    //     *

    //    ***

    //   *****

    //    ***

    //     *

    //

    //上三角

    //行数   空格数   星号数  换行

    //1     2       1       1

    //2     1       3       1

    //3     0       5       1

    //空格与行数的关系是: 空格 = n(边长) - 行数

    //星号与行数的关系是: 星号 = 行数*2 - 1

    //换行始终是一个

    int n = 0;

    printf("请输入一个边长,我们将为你打印n边菱形:\n");

    scanf("%d",&n);

    for (int i = 1; i <= n; i++) {

        //打印空格

        for (int j = 0; j < n - i; j++) {

            printf(" ");

        }

        //打印星号

        for (int k = 0; k < 2 * i - 1; k++) {

            printf("*");

        }

        //打印换行

        printf("\n");

    }

    //下三角

    //行数   空格数   星号数  换行

    //1     1       3       1

    //2     2       1       1

    //空格与行数的关系是: 空格 = 行数

    //星号与行数的关系是: 星号 = (n - 行数)*2 - 1

    //换行始终是一个

    for (int i = 1; i < n; i++) {

        //打印空格

        for (int j = 0; j < i; j++) {

            printf(" ");

        }

        //打印星号

        for (int k = 0; k < (n - i) * 2 - 1; k++) {

            printf("*");

        }

        //打印换行

        printf("\n");

    }


  边长为 n 的空心菱形

    int n = 0;

    printf("请输入一个边长,我们将为你打印n边菱形:");

    scanf("%d",&n);

    //上三角

    //行数   空格数   星号数 空格数 星号数 换行

    //1     2       1       0     0     1

    //2     1       1       1     1     1

    //3     0       1       3     1     1

    //前面空格与行数的关系是: 空格 = n(边长) - 行数

    //星号与行数的关系是: 星号 = 1

    //中间空格与行数的关系是: 空格 = (行数-1) * 2 -1

    //后面星号 行数为1的时候,0,行数不为1的时候1

    //换行始终是一个

    for (int i = 1; i <= n; i++) {

        //打印前面空格

        for (int j = 0; j < n - i; j++) {

            printf(" ");

        }

        //打印前面星号

        printf("*");

        //打印中间空格

        for (int k = 0; k < (i - 1)*2 -1; k++) {

            printf(" ");

        }

        //打印后面星号

        if (i != 1) {

            printf("*");

        }

        //打印换行

        printf("\n");

    }

    //下三角

    //行数   空格数 星号数  空格数 换行

    //1     1       1      3    1

    //2     2       1      1    1

    //3     3       1      0    1

    //空格与行数的关系是: 空格 = 行数

    //星号与行数的关系是: 星号 = 1

    //空格与行数的关系是: 空格 = (n - 行数 - 1)*2 - 1

    //星号与行数的关系是: 如果行数等于n-1,*0,否则是1

    //换行始终是一个

    for (int i = 1; i < n; i++) {

        //打印前面空格

        for (int j = 0; j < i; j++) {

            printf(" ");

        }

        //打印星号

        printf("*");

        //打印中间空格

        for (int k = 0; k < (n-1-i)*2 -1; k++) {

            printf(" ");

        }

        //打印后面星号

        if (i != n-1) {

            printf("*");

        }

        //打印换行

        printf("\n");

    }




  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值