问题描述
本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印
所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。
给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。
输入格式
输入在一行给出1个正整数N(≤1000)和一个符号,中间以空格分隔。
输出格式
首先打印出由给定符号组成的最大的沙漏形状,最后在一行中输出剩下没用掉的符号数。
样例输入
19 *
样例输出
C++代码
#include<bits/stdc++.h>
using namespace std;
int sum(int i){
return 2*i*i - 1;
}
int findk(int n){
for(int i=1;i<50;i++){
if(sum(i)<=n&&sum(i+1)>n)
return i-1;
}
}
void outspace(int k){
for(int i=0;i<k;i++){
printf(" ");
}
}
void outc(int k,char c){
for(int i=0;i<k;i++){
printf("%c",c);
}
}
void upout(int k,char c){
int i=2*k+1,j=0;
while(k--){
outspace(j);
outc(i,c);
cout<<endl;
i-=2;
j+=1;
}
}
void midout(int k,char c){
outspace(k);
cout<<c<<endl;
}
void downout(int k,char c){
int i=3,j=k-1;
while(k--){
outspace(j);
outc(i,c);
cout<<endl;
i+=2;
j-=1;
}
}
int main(){
int n;
char c;
cin>>n>>c;
int k = findk(n);
upout(k,c);
outspace(k); cout<<c<<endl;
downout(k,c);
if(n-sum(k+1)!=0)
cout<<n-sum(k+1);
return 0;
}
备注
一个测试点错误……
我的代码好丑
Think Twice,Code Once !!!