7-1 打印沙漏 (20 分)
本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印
*****
***
*
***
*****
所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。
给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。
1、实验代码
#include<stdio.h>
int main()
{
int n;
char c;
scanf("%d %c",&n,&c);
int i=1,sum=1;
while(sum<=n)
{
sum+=2*(2*(i+1)-1);
i++;
}
i=i-1;
int j,k;
for(j=0;j<i;j++)
{
for(k=0;k<j;k++)
printf(" ");
for(k=0;k<2*(i-j)-1;k++)
{
printf("%c",c);
}
printf("
");
}
for(j=2;j<=i;j++)
{
for(k=0;k<i-j;k++)
printf(" ");
for(k=0;k<2*j-1;k++)
{
printf("%c",c);
}
printf("
");
}
printf("%d",n-(sum-2*(2*(i+1)-1)));
return 0;
}
2、设计思路
第一步:先找出该题的突破点,很明显,这道题要求的沙漏是一个对称的形状;
第二步:再确定图形中字符个数是等差这么个规律,空格的个数可以根据每一行来确定;
第三步:利用等差求和公式,先计算所输入数字能输出的最大沙漏所需要的字符数,在计算总字符数时,注意细节,多算的最后要减去;
第四步:分两部分写,先打印上半部分,再打印下半部分;
第五步:输出结果,注意求余数时,要记得算总数时多加了,要减去。
3、本题调试过程碰到的问题及解决方法
说实话这道题一开始我并不会,是在借鉴别人的代码后,自己又看看才弄懂的。所以.....问题还是有的,而且很大。
4、运行结果截图
忘记截了,时间过了......