• 1027 打印沙漏 (20 分)C语言


    题目描述

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

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

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

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

    输入描述:

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

    输出描述:

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

    输入例子:

    19 *
    

    输出例子:

    *****
     ***
     *
     ***
    *****
    2
    
    #include <stdio.h>
    #include <math.h>//调用sqrt()函数的头文件
    int main(){
    	int n,i,j;
    	char c;
    	scanf("%d %c",&n,&c);//读入数和字符 
    	int chu=(int)sqrt(2.0*(n+1))-1;//最多的一行的个数,sqrt()计算一个非负实数的平方根
    	if(chu%2==0) chu--;//保证每行输出奇数个
    	int sum=(chu+1)*(chu+1)/2-1;//所需总数
    	for(i=chu;i>=1;i=i-2){//输出上面的部分 
    		for(j=0;j<(chu-i)/2;j++){
    			printf(" ");
    		}
    		for(j=0;j<i;j++){
    			printf("%c",c);
    		}
    		printf("
    "); 
    	}
    	for(i=3;i<=chu;i=i+2){//输出下面的部分 
    		for(j=0;j<(chu-i)/2;j++){
    			printf(" ");
    		}
    		for(j=0;j<i;j++){
    			printf("%c",c);
    		}
    		printf("
    "); 
    	} 
    	printf("%d
    ",n-sum);//输出多余的符号数 
    	return 0;
    } 
    
    欢迎查阅
  • 相关阅读:
    Spring+Springmvc+SpringJDBC+freemaker+Logback配置
    POJ1942+找规律
    HDU2955+DP+背包变形
    HDU1201+简单题
    HDU1288+枚举
    面试经验(转)
    HDU1864+dp+类似背包
    PKU1659+havelhakimi定理
    算法复杂度分析(摘)
    HDU3047+并查集
  • 原文地址:https://www.cnblogs.com/gh110/p/12158231.html
Copyright © 2020-2023  润新知