zoukankan      html  css  js  c++  java
  • 打印沙漏

    题目:

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

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

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

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

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

    输入格式:

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

    输出格式:

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

    输入样例:

    19 *
    
     

    输出样例:

    *****
     ***
      *
     ***
    *****
    2
    
     PTA的一道水题,不过把我硬是卡了一个小时,一直是格式错误,我心态差点崩了:

     后面搜了下其他博主的题解->_->,才知道PTA有多坑:

    这道题有两个要注意的地方:

     一是 最后在一行中输出剩下没用掉的符号数。即便是零个也要输出。

    二是 中间对齐的时候,只需输出符号前面的空格,符号后面的空格不要输出,不然会报格式错误!!!

    后面改了就AC了,代码其实很简单一道模拟题:

    #include<stdio.h>
    #include<math.h>
    int main(void)
    {
        int n,i,k=0,l,cnt,x,an;
        char ch;
        scanf("%d %c",&n,&ch);
        x=sqrt((n+1)/2);//通过这个计算出沙漏的层数 
        an=n-2*x*x+1;
        //printf("x:%d an:%d
    ",x,an);这个是测试数据的时候用的 
        l=2*x-1;
        for(i=l,k=0;i>1;i-=2,k++)
        {
            for(int j=0;j<k;j++)
            printf(" ");
            for(int j=0;j<i;j++)
            printf("%c",ch);//这里一定不要在后面输出空格,前车之鉴。 
            printf("
    ");
        }
        for(int i=0;i<(l-1)/2;i++)
        printf(" ");
        printf("%c",ch);//这里同上 
        printf("
    ");
        for(i=3;i<=l;i+=2,k--)
        {
            for(int j=1;j<k;j++)
            printf(" ");
            for(int j=0;j<i;j++)
            printf("%c",ch);//这里同上 
            printf("
    ");
        }
        //这里不管an是不是0都要输出,太坑了。 
        printf("%d
    ",an);
        return 0;
    }

    OK,这道题就AC啦:

  • 相关阅读:
    SqlServer数据库同步方案详解(包括跨网段)
    makefile 和shell文件相互调用
    处理百万级以上的数据处理
    makefile Template(添加多个lib)
    Linux下如何删除非空目录
    makefile Template
    g++ 编译和链接
    gcc include路径
    C++ XML解析之TinyXML篇
    利用Lucene.net搭建站内搜索(2)分词技术
  • 原文地址:https://www.cnblogs.com/Mangata/p/12321535.html
Copyright © 2011-2022 走看看