闲来无事,刷一波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; }