算法笔记3.3D: 沙漏图形 tri2str [1*+]

题目描述


问题:输入n,输出正倒n层星号三角形。首行顶格,星号间有一空格,效果见样例


样例输入


3


样例输出


* * *
 * * 
  *
 * * 
* * *

数据规模 1<= n <=50 

代码

#include<stdio.h>

int main(){
    int n;  //数据规模n
    while(scanf("%d", &n) != EOF){
        for(int i = 0; i < n ; i++){            //输出上三角
            for(int j = n; j > n - i; j--)
                printf(" ");
            for(int k = n ; k > i; k--){
                if(k == i)
                    printf("*");
                else
                    printf("* ");
            }
            for(int j = n; j > n - i; j--)
                printf(" ");
            printf("\n");
        }

        for(int i = 0; i < n - 1 ; i++){        //输出下三角
            for(int j = 0; j < n - i - 2; j++)
                printf(" ");
            for(int k = n ; k >= n - i - 1; k--){
                
                if(k == n - i - 1)
                    printf("*");
                else
                    printf("* ");
            }
            for(int j = 0; j < n - i - 2; j++)
                printf(" ");
            printf("\n");
        }
    }
    return 0;
}


总结:几个for循环的嵌套,难点for循环的判断条件,判断条件写出不熟练,需要多加练习。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值