码迷,mamicode.com
首页 > 其他好文 > 详细

打印沙漏

时间:2019-02-26 00:50:41      阅读:142      评论:0      收藏:0      [点我收藏+]

标签:scan   中间   stdio.h   int   --   形状   return   amp   scanf   

打印沙漏 (20 分)

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

 

*****

 ***

  *

 ***

*****

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

 

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

 

输入格式:

 

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

 

输出格式:

 

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

 

输入样例:

 

19 *

输出样例:

 

*****

 ***

  *

 ***

*****

2

#include<stdio.h>

int main()

{

    int i,j,t,n,a[25],m,k;

    char c;

    a[1]=1;

    t=3;

    for(i=2;i<25;i++)

    {

        a[i]=a[i-1]+2*t;

        t+=2;

    }

    while(~scanf("%d %c",&n,&c))

    {

        for(k=1;;k++)

        {

            if(n<=a[k]) break;

        }

        k=k-1;

        t=a[k]-a[k-1];

        t=t/2;

        if(n<7) {k=1;t=1;}

        for(i=0;t-2*i>=1;i++)

        {

            for(j=0;j<i;j++)

                printf(" ");

            for(j=0;j<t-2*i;j++)

                printf("%c",c);

            printf("\n");

        }

        for(i-=2;i>=0;i--)

         {

            for(j=0;j<i;j++)

                printf(" ");

            for(j=0;j<t-2*i;j++)

                printf("%c",c);

            printf("\n");

        }

        printf("%d\n",n-a[k]);

    }

    return 0;

}

 

打印沙漏

标签:scan   中间   stdio.h   int   --   形状   return   amp   scanf   

原文地址:https://www.cnblogs.com/lwl123456789/p/10434856.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!