zoukankan      html  css  js  c++  java
  • 编程总结1

    7-1 打印沙漏 (20 分)

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

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

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

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

    输入格式:

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

    输出格式:

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

    输入样例:

    19 *
    

    输出样例:

    *****
     ***
      *
     ***
    *****
    2
    1)实验代码
    #include<stdio.h>
    int main()
    {
       int n;
       char c;
       scanf("%d %c",&n,&c);
       int i=1,sum=1;  //i代表行数,sum代表一共需要的字符 
       while(sum<=n)
       {
           sum+=2*(2*(i+1)-1);  //利用等差数列可知,每增加一行,需要增加2个字符,乘以2代表上下两部分 。为什么是(i+1),因为sum=1这一步不需要计算 
           i++;
       }
       i=i-1;  //i会多运行一次,所以要减1 
       
       int j,k;
       //打印上半部分
       for(j=0;j<i;j++)  //行数由i决定 
       {
           for(k=0;k<j;k++)
           printf(" ");  //打印空格 
           for(k=0;k<2*(i-j)-1;k++)  //打印的每行为奇数,利用等差数列 。为什么是(i-j),因为i已经确定,打印个数由j决定 。到最后只打印一个* 
           {
               printf("%c",c);  //打印* 
           }
           printf("
    ");  //换行 
        } 
        
       //打印下半部分
       for(j=2;j<=i;j++)  //要除去打印一个*的那行 
       {
           for(k=0;k<i-j;k++)  //注意有个空格在后面 
           printf(" ");
           for(k=0;k<2*j-1;k++)  //等差数列,越往下打印的越多 
           {
               printf("%c",c);
           }
           printf("
    ");
        } 
        printf("%d",n-(sum-2*(2*(i+1)-1)));  //还要多减一个2*(2*(i+1)-1是因为sum在前面多算了一次 
        
        return 0;
    }

    2)设计思路

    3)本题调试过程碰到问题及解决办法

    问题一:一开始搞不懂怎么表示

    解决办法:自己查资料,问同学。

    4)运行结果截图

  • 相关阅读:
    1 win10双系统安装ubuntu16.04和18.04(问题详细记录)
    一些操作记录备查
    SecureCRT中文乱码解决方法
    Oracle中的NVL函数
    本机不安装Oracle客户端,使用PL/SQL Developer连接远程数据库
    DevExpress DateEdit控件选择精确到秒
    DevExpress GridView 整理
    Linux 删除文件夹和文件的命令
    DevExpress之XtraReport 学习
    解决Visual Studio Community 2017工具栏中没有Report Viewer的问题
  • 原文地址:https://www.cnblogs.com/zx666/p/10408568.html
Copyright © 2011-2022 走看看