本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印
*****
***
*
*****
***
*
所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。
给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。
代码如下:
#include<iostream>
using namespace std;
int main()
{
int n;//给定符号的个数
char ch;//给定符号
cin>>n;
cin>>ch;
int a=1;
int b=1;//b是剩余的符号个数
//1111计算可以输出的函数2c-1,以及剩余符号数b
for(a=1;b>=0;a++)
{
b=n-(2*a*a-1);//用a,来计算可以最多的行数(2c-1)
}
int c;
c=a-2;//即上面输出c行,下面输出c-1行 ,本例子就是c=3
b=n-(2*c*c-1);//不能组成沙漏的计算剩余的符号个数
//22222打印上面的部分
for(int i=1;i<=c;i++)//重复c次, 打印出前c行
{
for(int k=i-1;k>0;k--)//先输出特定空格
{
cout<<" ";
}
for(int j=2*c-1-(i-1)*2;j>0;j--)//输出特定数目给定符号
{
cout<<ch;
}
cout<<endl; //换行
}
//33333打印下面的部分
for(int i=c-1;i>0;i--)//打印下面的c-1行
{
for(int k=i-1;k--;k>0)//先输出特定空格数
{
cout<<" ";
}
for(int j=2*c-1-(i-1)*2;j>0;j--)//再输出特定的符号数
{
cout<<ch;
}
cout<<endl; //换行
}
//cout<<"还剩余"<<b;
cout<<b;//输出剩余的符号个数b
return 0;
}










