zoukankan      html  css  js  c++  java
  • 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;
    }
    
    

    遇到的问题及解决方法

    解决方法将空格去掉

  • 相关阅读:
    Leetcode979 : Distribute Coins in Binary Tree 二叉树均匀分配硬币问题
    Leetcode547: Friend Circles 朋友圈问题
    线程安全的生产者消费者四种实现方法
    Leetcode823 : 因子二叉树问题
    Leetcode7 : Reverse Integer 整数反转问题
    Leetcode3 : 最长不含重复字符子串问题
    Leetcode6 : ZigZag 转换问题
    leetcode8 : 实现atoi函数将字符串转化为整数问题
    seo域名选择
    利用 Python django 框架 输入汉字,数字,字符,等。。转成二维码!
  • 原文地址:https://www.cnblogs.com/9557yxl/p/10458103.html
Copyright © 2011-2022 走看看