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

    7-1 打印沙漏 (20 分)

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

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

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

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

    输入格式:

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

    输出格式:

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

    输入样例:

    19 *
    
    

    输出样例:

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

    实验思路:

    分段打印,先打印上半部分以及中间的,之后再打印下半部分的。
    

    实验代码:

    #include <stdio.h>
    int main()
    {
    int m,n=0,i,j,k,x,y,a,b,c,d;
    char z;
    scanf("%d %c",&m,&z);
    if(m==1){  //先判定是否只有一个,是的话直接输出 
    	printf("%c
    ",z);
    	printf("0");
    }
    else { 
    do{
    	n++;	
    	x=m-2*n*n+1;
    }while(x>0);  
    n=n-1; //上半部分的行数 
    y=m-2*n*n+1;  // 把剩下没用掉的符号数求出来 
    a=2*n-1;  //上半部分第一行所需符号数 
    b=0;  //统计上半所需的空格数 
    for(i=0;i<n;i++){
    	
    for(j=0;j<b;j++){  //输出空格 
    printf(" "); 
    }
    for(k=0;k<a;k++){  //输出符号 
    printf("%c",z); 
    }
    a=a-2;  //每一行所需符号数少2个 
    b++;  //所需空格每一行多一个 
    printf("
    ");  //换行 
    }
    
    n=n-1;  //下半部分的行数 
    c=3;  // 下半部分第一行所需符号数 
    d=n-1;  //下半部分第一行所需空格数 
    for(i=0;i<n;i++){
    	
    for(j=0;j<d;j++){  //输出空格 
    printf(" "); 
    }
    for(k=0;k<c;k++){  //输出符号 
    printf("%c",z); 
    }
    c=c+2;  // 每一行所需符号数少2个
    d--;  // 所需空格每一行少一个 
    printf("
    ");  //换行 
    }
    printf("%d",y);  //输出没用掉的符号数 
    } 
    return 0;
    }
    

    实验截图:

  • 相关阅读:
    Prism-超轻量的开源框架
    1的数目
    二叉树中和为某一值得路径
    把二叉树打印成多行
    对称的二叉树
    二叉树的下一个节点
    删除链表中重复的结点
    数组中的重复数字
    连表中环入口的节点
    把字符串换成整数
  • 原文地址:https://www.cnblogs.com/zhuwanxing/p/10388832.html
Copyright © 2011-2022 走看看