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; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于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)