zoukankan      html  css  js  c++  java
  • 打印沙漏编程总结

    打印沙漏
    题目1: 打印沙漏 (20 分)
    本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印
    所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。
    给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。
    1实验代码

          #include<stdio.h>
          int main()
          {
                 int n;
                 char c;
                 scanf("%d %c",&n,&c);
                 int i=1,sum=1;
                 while(sum<=n)
                 {
                       sum+=2*(2*(i+1)-1);
                       i++;
                 }
                 i=i-1; 
                 int j,k;
                 for(j=0;j<i;j++)
                 {
                         for(k=0;k<j;k++)
                                 printf(" ");  
                         for(k=0;k<2*(i-j)-1;k++)  
                         {
                                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))); 
                    return 0;
           }
    

    2).设计思路
    1、定义并输入变量n,c,i=1,sum=1;
    2、利用while语句比较sum与n,求出i;
    3、定义变量j,k;
    4、利用for循环语句打印沙漏的上下部分并输出;
    5、求出并输出剩余字符。

    3)本题调试过程遇到的问题及解决办法
    开始拿到题不知道怎么做,没思路,后面看到同学写出来,有查资料,自己一步一步的问才明白
    4)运行结果截图

  • 相关阅读:
    2018年7月10日笔记
    2018年7月7日笔记
    2018年7月5日笔记
    2018年7月3日笔记
    sed 命令详解
    《软件构架实践》阅读笔记01
    《掌握需求过程》阅读笔记06
    《掌握需求过程》阅读笔记05
    第十二周进度条
    《掌握需求过程》阅读笔记04
  • 原文地址:https://www.cnblogs.com/ZHLJ477/p/10372044.html
Copyright © 2011-2022 走看看