L1-002 打印沙漏 (20分)
题目详情:
AC代码:
#include<iostream>
#include<iomanip>
using namespace std;
int main()
{
int n,sum=1,b=3,p,h=1,m;
char c;
cin>>n>>c;
p=(n-1)/2+1;//下半个漏斗的字符数
while(sum+b<=p)
{
h++;//下半个漏斗的行数
sum=sum+b;
b=b+2;
}
sum=n-sum*2+1;//剩余的字符数
m=1;
for(int i=h; i>1; i--)//倒着输下半个漏斗,即上半个漏斗
cout<<setw(m++)<<setfill(' ')<<c<<setw(2*i-2)<<setfill(c)<<c<<endl;//注意每一行字符的个数与下半个漏斗的行数之间的关系即2*行数-1,由于先输出一个字符。故剩下的为2*行数-2
cout<<setw(m)<<setfill(' ')<<c<<endl;//输出下半个漏斗的第一行
m--;
for(int i=2; i<=h; i++)//输下半个漏斗
cout<<setw(m--)<<setfill(' ')<<c<<setw(2*i-2)<<setfill(c)<<c<<endl;
cout<<sum<<endl;
return 0;
}
永远相信美好🎈