• 2019年寒假作业1


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

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

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

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

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

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

    输入样例:

    19 *
    

    输出样例:

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

    错误代码

    #include<stdio.h>
    int main(){
    	int number,temp=7,a=3;
    	char ch;
    	int yemp1,yemp2;
    	scanf("%d %c",&number,&ch);
    	do{
    		if(number>=temp){
    			if(number<(temp+2*(a+2))){
    				break;
    			}
    			else if(number==(temp+2*(a+2))){
    				temp=(temp+2*(a+2));
    				a=a+2;
    				break;
    			}
    			else{
    				temp=(temp+2*(a+2));
    				a=a+2;
    			}
    		}
    	}while(1);
    	for(int i=0;i<a;i++){
    		yemp1=i;
    			if(yemp1>a/2){
    				yemp1=a-yemp1-1;
    			}
    			for(int j=0;j<a;j++){
    				yemp2=j; 
    				if(yemp2>a/2){
    					yemp2=a-yemp2-1;
    				}
    				if(yemp2<yemp1){
    					if(j>a/2){
    						printf("
    ");
    						break;
    				}
    					else{
    						printf(" ");
    					}
    				}
    				else{
    					printf("%c",ch);
    				}
    				if(j==a-1){
    					printf("
    ");
    				}
    			}
    	}
    	printf("%d
    ",number-temp);
    }
    

    当时是在网上随便抄的没时间写这个补了个
    新代码

    #include <stdio.h>
    
    int main(void)
    {
        int N,sum=1,i=1;
        char c;
        int k,a;
    
        scanf("%d%c", &N, &c);
        while (sum<=N)
        {
            sum+ =2*(2*(i+1)-1);
            if (sum<= N)
                i++;
        }
    
        for (k=0;k<i;k++)
        {
            for(a=0;a<k;a++)
                printf(" ");
    
            for(a=0;a<2*(i-k)-1;a++)
                printf("%c",c);
    
            printf("
    ");
        }
    
        for(k=2;k<= i;k++)
        {
            for(a=0;a<i-k;a++)
                printf(" ");
    
            for (a=0;a<2*k-1;a++)
                printf("%c",c);
    
            printf("
    ");
        }
        printf("%d",N-(sum-2*(2*(i+1)-1)));
        return 0;
    }
    
    

    遇到的问题及解决方法

    解决方法将空格去掉

  • 相关阅读:
    快速掌握MIPI开发攻略,对接百度人工智能计算卡EdgeBoard
    百度大脑UNIT3.0解读之对话式文档问答——上传文档获取对话能力
    果蔬识别轻松帮你区分车厘子与大樱桃
    远场语音识别套件评测
    智能家居手势识别,只需百度AI即可搞定
    python callable函数(43)
    python range函数(42)
    python len函数(41)
    python filter函数(40)
    python 进程Process模块(40)
  • 原文地址:https://www.cnblogs.com/9557yxl/p/10458103.html
Copyright © 2020-2023  润新知