• 寒假作业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函数,上下重复打印就可以知道剩下的字符数

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

    运行结果:

  • 相关阅读:
    深入Java虚拟机(4)——网络移动性
    安装ftp碰到的问题及解决方法
    6.设置ListView的Item的高度无效
    hdu1181(变形课)
    ZooKeeper分布式集群部署及问题
    管理线程之创建线程
    Linux系统编程——多线程实现多任务
    Request.Params用法,后台接收httpget参数
    resharper警告 :linq replace with single call to FirstOrDefault
    SQL Prompt几个快捷键
  • 原文地址:https://www.cnblogs.com/lcj5657/p/10380726.html
Copyright © 2020-2023  润新知