#include<stdio.h>
int n;
char a;
int l; //记录最长的一行有多少个符号
int sum=1;
int rest;
int space;
int icon;
int s;
int i;
int main()
{
scanf("%d %c",&n,&a);
if(n<5){
rest=n-1;
printf("%c\n%d",a,rest);
return 0;
}
for(l=3;sum<=n;l+=2){ //测试余数为0的情况,此处sum<=n而不是sum<n
sum+=2*l;
}
l-=4;
rest=n-sum+l*2+4; //剩余的符号数
for(icon=l;icon>=1;icon-=2){
space=(l-icon)/2;
for(s=space;s>0;s--){
printf(" ");
}
for(i=icon;i>0;i--){
printf("%c",a);
}
printf("\n");
}
for(icon=3;icon<=l;icon+=2){
space=(l-icon)/2;
for(s=space;s>0;s--){
printf(" ");
}
for(i=icon;i>0;i--){
printf("%c",a);
}
printf("\n");
}
printf("%d",rest);
}
自测-1 打印沙漏 (20分)
最新推荐文章于 2019-07-04 10:36:23 发布