1027. 打印沙漏(20)

本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印

*****
 ***
  *
 ***
*****

所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。

给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。

输入格式:

输入在一行给出1个正整数N(<=1000)和一个符号,中间以空格分隔。

输出格式:

首先打印出由给定符号组成的最大的沙漏形状,最后在一行中输出剩下没用掉的符号数。

输入样例:

19 *

输出样例:

*****
 ***
  *
 ***
*****
2

 

复制代码
#include<cstdio>
#include<cmath>

int main(){
    int n;
    char c;
    scanf("%d %c",&n,&c);
    int bottom = (int)sqrt(2.0*(n+1))-1; //根据不等式推算出第一层的符号的个数 
    if(bottom % 2 == 0) bottom--;         //题目规定奇数个 
    int used = (bottom+1)*(bottom+1)/2-1;
    for(int i = bottom; i >= 1; i-=2){ //倒着输出三角形 
        for(int j = (bottom - i)/2; j >0; j--){    //空格个数和层次等式关系 
            printf(" ");
        }
        for(int j = 0; j < i; j++){
            printf("%c",c);
        }
        printf("\n");
    }
    for(int i = 3; i <= bottom; i +=2 ){   //输出正三角形形状,除去顶部那个点 
        for(int j = 0; j < (bottom -i)/2; j++){
            printf(" ");
        }
        for(int j = 0; j < i; j++)
        printf("%c",c);
        
        printf("\n");
    } 
    printf("%d\n",n-used);
    return 0;
}
复制代码

 

复制代码
//line找的不对,第三个测试点么通过。
#include<cstdio>
#include<cmath>

int getLine(int n){
    if(n > 1000) return 0;
    int x = 1;
    while(1){
        if((2*(x-1)*(x-1)<= n-1) &&(2*(x+2)*(x-1) >= n - 1))
         return x;
        else x++;
    }
}

int main(){
    int n;
    char c;
    scanf("%d %c",&n,&c);
    int line = getLine(n);
    int used = line * line * 2 - 1;
    int bottom = 2*line-1;
    
    for(int i = bottom; i >= 1; i -= 2){
        for(int j = 0; j <(bottom - i)/2; j++) printf(" ");
        for(int j = 0; j < i; j++) printf("%c",c);
        printf("\n");
    }
    for(int i = 3; i <= bottom; i += 2){
        for(int j = 0; j < (bottom - i)/2; j++) printf(" ");
        for(int j = 0; j < i; j++) printf("%c",c);
        printf("\n");
    }
    
    printf("%d\n",n - used);
    return 0;
} 
复制代码

 

posted @   王清河  阅读(123)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示