PAT练习题:打印沙漏

来源:互联网 发布:tensorflow models 编辑:程序博客网 时间:2024/05/16 03:39

自测-1 打印沙漏   (20分)

本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印

***** ***  * ********

所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。

给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。

输入格式:

输入在一行给出1个正整数N(\le1000)和一个符号,中间以空格分隔。

输出格式:

首先打印出由给定符号组成的最大的沙漏形状,最后在一行中输出剩下没用掉的符号数。

输入样例:

19 *

输出样例:

***** ***  * ********2


解题思路:

1.根据给定的正整数N,计算出第一行要打印的个数。
2.打印倒三角
3.打印正三角
4.计算余下的符号数

代码示例:

#include<stdio.h>int linenumber(int n){                  //计算第一行打印符号个数 int i=1;int num=1;while(num<n){i=i+2;num=num+i*2;}if(num>n)i=i-2;return i;}int main(){int i,j,m,n,num=0;char ch;scanf("%d %c",&n,&ch);i=linenumber(n);for(m=i;m>0;m=m-2){                   //打印倒三角 for(j=0;j<(i-m)/2;j++)            //打印空格 printf(" ");                   for(j=0;j<m;j++)                  //打印字符 printf("%c",ch);printf("\n");num=num+m;}for(m=3;m<=i;m=m+2){                  //打印正三角,从第二行开始 for(j=0;j<(i-m)/2;j++)            //打印空格 printf(" ");                   for(j=0;j<m;j++)                  //打印字符 printf("%c",ch);printf("\n");}printf("%d",n-(num*2-1));return 0;}




原创粉丝点击