1027 打印沙漏 (20 分)
本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印
所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。
给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。
输入格式:
输入在一行给出1个正整数N(≤1000)和一个符号,中间以空格分隔。
输出格式:
首先打印出由给定符号组成的最大的沙漏形状,最后在一行中输出剩下没用掉的符号数。
输入样例:
19 *
输出样例:
2
1027较简单,但是笔者认为笔者这个程序较冗长,欢迎大家给出意见,这道题其实只要建一个数组得出每一行的符号数即可,然后再用一个数来标记每一行应该输出的符号数。
#include<stdio.h>
int main(){
int N;
char c;
scanf("%d %c",&N,&c);
int a[1000];
int i;
int sum=0;
for(i=0;;i++){//用一个数组统计每一行应该输出的符号数
if(((sum+2*i)*2+1)<=N){
a[i]=2*i+1;
sum=sum+a[i];
}
else
break;
}
int k=0;//用来输出空格
int h;
for(int j=i-1;j>=0;j--){//输出上半段
h=k;
int count=a[j];
while(count>0){
while(h>0){//输出空格
printf(" ");
h--;
}
printf("%c",c);
count--;
}
k++;
printf("\n");
}
k=k-2;
for(int j=1;j<i;j++){//输出下半段
h=k;
int count=a[j];
while(count>0){
while(h>0){
printf(" ");
h--;
}
printf("%c",c);
count--;
}
printf("\n");
k--;
}
printf("%d",N-2*sum+1);
return 0;
}