本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印

*****
***
*
***
*****

所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。

给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。

输入格式:

输入在一行给出1个正整数N(≤1000)和一个符号,中间以空格分隔。

输出格式:

首先打印出由给定符号组成的最大的沙漏形状,最后在一行中输出剩下没用掉的符号数。

输入样例:

19 *

输出样例:

*****
***
*
***
*****
2

先计算出最大的行数, 然后分3块打印,比如样例 上面是 5 3 , 中间 1 , 下面 是 3 5 , 这种对称性的图形一般都是有规律的,

打完上面,下面也一样的计算方法 . 

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <ctime>
#include <cmath>
using namespace std ;
const int MAX = 100005 ;
typedef long long LL ;

int main(){
int n ;
char ch ;
cin >> n >> ch;

int Max = 1 ;
int cnt = 0 ;
for(int i = 3 ; i<=1000 ; i+=2){

if(Max +2*(i) >n ){
break ;
}
else{
Max+=2*(i) ;
cnt++;
}
}
int t = 0 ; // 控制空格
// 控制上面的行
for(int i = cnt ; i>=1 ; i-- ) {
//打印空格
for(int k = 1 ;k<=t ; k++) {
cout<<" " ;
}
//打印符号
for(int j = 1 ; j<=2*i+1 ; j++) {
cout<<ch;
}
cout<<endl;
t++;
}
for(int i = 1 ; i<=t ;i++ ) {
cout<<" " ;
}
cout<<ch <<endl ;
t-- ;
for(int i = 1 ; i<=cnt ;i++ ) {
for(int k = 1 ; k<=t; k++) {
cout<<" " ;
}

for(int j = 1 ; j<=2*i+1 ; j++) {
cout<<ch;
}
cout<<endl;
t-- ;
}
cout<<n-Max<<endl;
return 0 ;
}