zoukankan      html  css  js  c++  java
  • pat00-自测1. 打印沙漏(20)

    00-自测1. 打印沙漏(20)

    时间限制
    200 ms
    内存限制
    65536 kB
    代码长度限制
    8000 B
    判题程序
    Standard
    作者
    CHEN, Yue

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

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

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

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

    输入格式:

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

    输出格式:

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

    输入样例:
    19 *
    
    输出样例:
    *****
     ***
      *
     ***
    *****
    2
    

    提交代码

     1 #include <cstdio>
     2 #include <cstring>
     3 #include <string>
     4 #include <queue>
     5 #include <cmath>
     6 #include <iostream>
     7 using namespace std;
     8 int main(){
     9     int n;
    10     char c;
    11     cin>>n>>c;
    12     int k=sqrt(1.0*(n+1)/2);
    13     int i,maxnum=2*k-1;
    14     for(i=maxnum;i>=1;i-=2){
    15         int j=0;
    16         for(j=0;j<(maxnum-i)/2;j++){
    17             cout<<" ";
    18         }
    19         for(j=0;j<i;j++){
    20             cout<<c;
    21         }
    22         cout<<endl;
    23     }
    24     for(i=3;i<=maxnum;i+=2){
    25         int j=0;
    26         for(j=0;j<(maxnum-i)/2;j++){
    27             cout<<" ";
    28         }
    29         for(j=0;j<i;j++){
    30             cout<<c;
    31         }
    32         cout<<endl;
    33     }
    34     cout<<n+1-2*k*k<<endl;
    35     return 0;
    36 }
  • 相关阅读:
    LDA的整体流程
    java中字符串的用法
    verification Code
    properties
    Hash
    substring的问题
    LDA和PLSA的区别
    Step By Step(Lua环境)
    Step By Step(Lua调用C函数)
    Step By Step(Lua弱引用table)
  • 原文地址:https://www.cnblogs.com/Deribs4/p/4713016.html
Copyright © 2011-2022 走看看