用C语言打印沙漏问题
本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印
*****
***
*
***
*****
所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。
给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。
输入格式:
输入在一行给出1个正整数N(≤1000)和一个符号,中间以空格分隔。
输出格式:
首先打印出由给定符号组成的最大的沙漏形状,最后在一行中输出剩下没用掉的符号数。
输入样例:
19 *
输出样例:
*****
***
*
***
*****
2
代码
#include<stdio.h>
int main()
{
int N,n,i,j;//N为给的数量,n为行数
char c;
scanf("%d %c",&N,&c);
N--,n=1;//N先减去原来中间那一行的那一个星星
while(N>(n+2)*2)//如果剩下来的N大于下一次可以增加的星星数,那么则打印下一次的星星
{ N-=(n+2)*2; //N减去相应需要的星星数
n+=2;//加上相应的行数
}
//现在得到可以打印的星星的行数还有数量
//开始打印
int a=n,b=1;//将行数n赋值给a,避免直接将行数n代入计算影响行数a的数值
for(i=1;i<=n;i++)//外循环打印列,内循环打印行
{ if(i<=n/2)//打印前两行(本题)
{ for(j=0;j<i-1;j++)//打印空格
printf(" ");
//发现规律:第一行的星星数与行数n相等
for(j=0;j<a;j++)
printf("%c",c);
a-=2;//每行打印结束将星星打印数a减少两个
}
else//开始打印剩下的行数
{ for(j=n-i;j>0;j--)//每一行的空格数等于总行数n减去i的值
printf(" ");
for(j=b;j>0;j--)//打印的星星数从1开始
printf("%c",c);
b+=2;//每行打印结束将星星数增加两个
}
printf("\n");//每行循环结束打印换行
}
printf("%d",N);//N变为打印剩下的数字,直接打印
return 0;
}