PTA编程总结1
<p>本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印</p>
<hr />
<hr />
<p>*</p>
<hr />
<hr />
<p>所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。
给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。
include
int main() { int i,j,k,s,t,l,n,res; char a; int str[30]={1,7,17,31}; for(i=3;i<30;i++) { str[i]=str[i-1]+6+(i-1)4; //按规律给数组赋值 } scanf("%d %c",&n,&a); for(k=0;k<30;k++) { if(n<str[k]) break; //n与数组的值比较 res=n-str[k]; //计算没用掉的符号数 } t=k;l=k; //t,l供接下来打印图形用 for(i=0;i<k;i++) { for(j=0;j<i;j++) { printf(" "); } for(j=0;j<2t-1;j++) { printf("%c",a); } t--; printf("\n"); } for(i=0,t=l-2;i<k-1;i++,t--) { for(j=0;j<t;j++) { printf(" "); } for(j=0;j<2*(i+1)+1;j++) { printf("%c",a); } printf("\n"); } printf("%d\n",res); } 2) 设计思路 4).运行结果截图</p>
给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。
include
int main() { int i,j,k,s,t,l,n,res; char a; int str[30]={1,7,17,31}; for(i=3;i<30;i++) { str[i]=str[i-1]+6+(i-1)4; //按规律给数组赋值 } scanf("%d %c",&n,&a); for(k=0;k<30;k++) { if(n<str[k]) break; //n与数组的值比较 res=n-str[k]; //计算没用掉的符号数 } t=k;l=k; //t,l供接下来打印图形用 for(i=0;i<k;i++) { for(j=0;j<i;j++) { printf(" "); } for(j=0;j<2t-1;j++) { printf("%c",a); } t--; printf("\n"); } for(i=0,t=l-2;i<k-1;i++,t--) { for(j=0;j<t;j++) { printf(" "); } for(j=0;j<2*(i+1)+1;j++) { printf("%c",a); } printf("\n"); } printf("%d\n",res); } 2) 设计思路 4).运行结果截图</p>