码迷,mamicode.com
首页 > 其他好文 > 详细

1027 打印沙漏

时间:2020-02-18 13:04:22      阅读:72      评论:0      收藏:0      [点我收藏+]

标签:span   turn   几分钟   layer   char   iostream   字符   mic   name   

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

#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 打印沙漏

标签:span   turn   几分钟   layer   char   iostream   字符   mic   name   

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!