本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印
*****
***
*
***
*****
所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。
给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。
输入格式:
输入在一行给出1个正整数N(≤1000)和一个符号,中间以空格分隔。
输出格式:
首先打印出由给定符号组成的最大的沙漏形状,最后在一行中输出剩下没用掉的符号数。
输入样例:
19 *
输出样例:
*****
***
*
***
*****
2
我的代码:
#include<stdio.h>
int main()
{
int ch,n,i,q,m,b,a,c,d,g;
i=1;
q=1;
b=0;
g=0;
scanf("%d %c",&n,&ch);
while(1){
i=i+2;
q=q+2*i;
if(q>n)
break;
}
for(m=i-2;m>=1;m=m-2){
if(b>0)
for(c=1;c<=b;c++){
printf(" ");
}
b++;
g=g+m;
for(a=1;a<=m;a++){
printf("%c",ch);
}
printf("\n");
}
b--;
for(m=3;m<=i-2;m=m+2){
b--;
if(b>0)
for(c=1;c<=b;c++){
printf(" ");
}
for(d=1;d<=m;d++){
printf("%c",ch);
}
printf("\n");
}
printf("%d",n+1-2*g);
return 0;
}
实验思路:
第一步:定义整形变量。
第二步:运用WHILE循环判断沙漏上半部分该如何打印,该有几层。
第三步:运用for循环进行沙漏上半部分的打印。
第四步:通过for循环进行沙漏下半部分的打印。
第五步:printf输出所需答案。
第六步:结束程序。
错误结果:
分析:下半部分沙漏判断错误,没有达到题目所要求的输出,忘记输出剩下图像个数。
运行结果: