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=1,m=1,i=1,j,k,l,flag=0;
      char op;
      scanf("%d %c",&m,&op);
      while(n<m)
      {
        n=n+(i+2)*2;
        i=i+2;
      }
      if(n>m)
      {
        n=n-i*2;
        i=i-2;
      }
      for(j=1;j<=i/2;j++)
      {
        for(k=0;k<flag;k++)
        printf(" ");
        for(k=0;k<i-flag*2;k++)
        printf("%c",op);
        flag++;
        printf("
    ");
      }
      for(j=0;j<i/2;j++)
      printf(" ");
      printf("%c
    ",op);
      flag--;
      for(j=(i/2)+1;j<i;j++)
      {
        for(k=0;k<flag;k++)
        printf(" ");
        for(k=0;k<i-flag*2;k++)
        printf("%c",op);
        printf("
    ");
        flag--;
      }
      printf("%d",m-n);
    }
    
    

    设计思路:

    计算处层数

    字符打印只是一个2的n-1次方-1函数,上下重复打印就可以知道剩下的字符数

    值得注意的就是空格打印不同字符是相反的

    运行结果:

  • 相关阅读:
    Samba 基础搭建
    HBuilder 打包流程和遇到的坑
    js 字符串查找相同字母最长子串
    web前端简单的H5本地存储
    rem响应式JS
    JS洗牌算法
    Js 常用正则表达式
    JS_DOM_鼠标、键盘事件合集
    SE 2014年4月3日
    SE 2014年4月2日
  • 原文地址:https://www.cnblogs.com/lcj5657/p/10380726.html
Copyright © 2011-2022 走看看