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

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

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

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

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

    输入格式:

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

    输出格式:

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

    输入样例:

    19 *
    

    输出样例:

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

    解答:
     1 //每一行打印符号之后直接回车,不用打印空格
     2 #include<stdio.h>
     3 int main(){
     4     int i,j,k,n,l=1,t;
     5     char c=' ';
     6     scanf("%d %c",&n,&c);
     7     while(l*l*2-1<=n){
     8         l++;
     9     }
    10     l--;//得到打印上三角的行数
    11     k=l;
    12     for(i=1;i<=k;i++){//打印上三角
    13         for(j=1;j<i;j++){
    14             printf(" ");
    15         }
    16         for(j=1;j<=2*l-1;j++){
    17             printf("%c",c);
    18         }
    19         l--;
    20         printf("
    ");
    21     }
    22     t=k;
    23     l=2;//下三角从第二行开始打印
    24     for(i=2;i<=k;i++){//打印下三角
    25         for(j=1;j<=t-i;j++){
    26             printf(" ");
    27         }
    28         for(j=2*l-1;j>0;j--){
    29             printf("%c",c);
    30         }
    31         printf("
    ");
    32         l++;
    33     }
    34     printf("%d
    ",n-(2*t*t-1));
    35     return 0;
    36 }
    我的思路:题中每行输出奇数个符号,相邻两行符号数差2,从上三角看起,可以看出每一行的符号个数是成等差数列

    1.先通过输入的符号个数得到上三角的行数

    2.打印上三角:先打印空格,空格个数通过行号控制,再打印符号,符号的个数也通过行号控制,然后打印回车

    3.下三角打印类似上三角,不过下三角的打印从第二行开始,下三角的第一行就是上三角的最后一行

    4.得到剩余符号个数


    不足错误的地方,欢迎拍砖!
    心之所向,素履以往
  • 相关阅读:
    mysql 设置无密码登陆
    phpstudy mysql 升级5.7.18
    php 统计二维数组中某个相等值的总个数,并且组合成一个新的数组 转发
    centos 安装 composer
    PHP不定维数组去除空值
    jQuery中$.ajax()详解(转)
    JSON详解(转发自博客园)
    详解CMS垃圾回收机制
    内存管理
    什么是同源策略
  • 原文地址:https://www.cnblogs.com/yinbiao/p/8056236.html
Copyright © 2011-2022 走看看