首页 > 其他 > 详细

1027 打印沙漏

时间:2020-02-18 12:33:19      阅读:58      评论:0      收藏:0      [点我收藏+]

水题。在计算层数的时候卡了十几分钟,我好菜。

#include<iostream>
using namespace std;
int main() {
    int N;
    char c;
    cin>>N>>c;
    int layer = 1,sum = 1;//sum表示层数layer对应的总字符数 
    while(N > sum + ((layer+1)*2-1)*2) { //找出上半三角型的层数 layer 
        sum += ((layer+1)*2-1)*2;
        layer++;
    }
    int temp = layer;
    while(layer > 0) {//输出上半三角形
        for(int j = temp - layer; j > 0 ; --j) {
            printf(" ");
        }
        for(int i = 1; i <= 2*layer-1; ++i) {
            printf("%c",c);
        }
        printf("\n");
        layer--;
    }
    layer = 2;
    while(layer <= temp) {//输出下半三角形
        for(int j = temp - layer; j > 0 ; --j) {
            printf(" ");
        }
        for(int i = 1; i <= 2*layer-1; ++i) {
            printf("%c",c);
        }
        printf("\n");
        layer++;
    }
    cout<<N-sum;// 输出剩下没用掉的符号数
    return 0;
}

技术分享图片

 

1027 打印沙漏

原文:https://www.cnblogs.com/keep23456/p/12325554.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!