閒來無事,刷一波PAT,這是PAT練習題第六題,題目大意是用是輸入的字元列印一個沙漏形狀,比如給了19個“c”,就得列印包括儘量多的“c”的沙漏,和剩餘的“c”個數。結果如下
ccccc
ccc
c
ccc
ccccc
2
大致分了兩個部分解答。
一個是算出沙漏的高度,這裡我用的是查詢的方法;
二是根據高度列印沙漏,這就看迴圈的熟練程度了。
#include<stdio.h>
int main(){
int a[25]={0};
for(int i=1;i<25;i ){
a[i]=2*i*i-1;
}
int n;//n<=1000
char c;
scanf("%d %c",&n,&c);
int les;
int h;
for(int i=1;i<25;i ){
if(n-a[i]<0){
les=n-a[i-1];
h=i-1;
break;
}
}
for(int i=1;i<=h;i ){
for(int j=1;j<i;j ){
printf(" ");
}
for(int k=1;k<=2*h 1-2*i;k ){
printf("%c",c);
}
printf("\n");
}
for(int i=1;i<=h-1;i ){
for(int j=1;j<h-i;j ){
printf(" ");
}
for(int k=1;k<=2*i 1;k ){
printf("%c",c);
}
printf("\n");
}
printf("%d\n",les);
return 0;
}
写评论
很抱歉,必須登入網站才能發佈留言。