【context】
题目要求
本题要求写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印
*****
***
*
***
*****
所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。
给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。
输入格式
输入在一行给出1个正整数N(≤1000)和一个符号,中间以空格分隔。
输出格式
首先打印出由给定符号组成的最大的沙漏形状,最后在一行中输出剩下没用掉的符号数。
输入样例
19 *
输出样例
*****
***
*
***
*****
2
解题分析
①找到规律:每一行字符由*与空格组成,随着行数的改变,*递减,空格数递增。
②找出* 空格与行数i之间的关系,如此在for循环中可以更容易地找出规律。
初次尝试(错误原因及分析
#include<stdio.h>
#include&

本文详细介绍了如何编写程序来打印沙漏形状的图案,分析了输入输出格式、解题思路以及初次尝试时出现的错误及其修正。通过举例和解题过程,阐述了如何找出打印行数与符号之间的关系,最终得出正确运行的代码。同时,文章强调了在编程过程中寻找规律和调试的重要性。
最低0.47元/天 解锁文章





