zoukankan      html  css  js  c++  java
  • PTA寒假一

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





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

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

    输入格式:

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

    输出格式:

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

    输入样例:

    19 *
    输出样例:





    2
    实验代码

    include<stdio.h>

    int main(){
    //定义代码所需要的变量
    //temp=7是打印沙漏图形至少所需的符号量,a=3为最小沙漏图形的行数
    int number,temp=7,a=3;
    char ch;
    int yemp1,yemp2;
    scanf("%d %c",&number,&ch);
    //如下部分代码是为了确定给定的数可以打印出最大沙漏的行数
    do{
    //先判断给定的数number是否可以打印沙漏图形
    if(number>=temp){
    //判断给定的数number是否可以打印下一个更大的沙漏图形
    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);

    //如下的代码根据所给定的行数打印出与此相匹配的沙漏图像
    //i代表行数,j代表列数 
    //在如下的代码中之所以引入yemp1,yemp2的原因是因为,将比较大的行转化为比较小行的操作中需要用到,因为不能直接对代表行数的i,j进行直接的操作,假使这样做会是使源代码无限循环 
    for(int i=0;i<a;i++){
    	yemp1=i;
    		//如果行数大于a/2(即中心行),那么将该行转化为与此行一样的更小的行,转换的规则为: yemp1=a-yemp1-1;
    		if(yemp1>a/2){
    			yemp1=a-yemp1-1;
    		}
    		for(int j=0;j<a;j++){
    			//如果列数大于a/2(即中心列),那么将该列转化为与此列一样的更小的列,转换的规则为: yemp2=a-yemp2-1;
    			yemp2=j; 
    			if(yemp2>a/2){
    				yemp2=a-yemp2-1;
    			}
    			//如果转换为等效列的列数yemp2小于行数yemp1,
    			if(yemp2<yemp1){
    				//如果列数大于 a/2(中心列),则跳行,跳出循环(其实这里也可以输出空格的,然后在列的末尾跳行,只不过为了减少循环而选择将沙漏图形后面的空格用换行代替) 
    				if(j>a/2){
    					printf("
    ");
    					break;
    			}
    				//如果列数小于 a/2(中心列),则输出空格 
    				else{
    					printf(" ");
    				}
    			}
    			//如果转换为等效列的列数yemp2大于等于行数yemp1,则输出字符 
    			else{
    				printf("%c",ch);
    			}
    			//末尾列换行 
    			if(j==a-1){
    				printf("
    ");
    			}
    		}
    }
    //输出多余的符号 
    printf("%d
    ",number-temp);
    

    }
    思路
    第一步:定义变量
    第二步:因为跟以前的倒三角类似,所以运用了类似的方法;
    第三步:运用while语句
    第四步:打印输出

    三.本题调试过程碰到问题及解决办法
    跟以前的倒三角类似,所以运用了类似的方法,然后参考别人的才做出来
    4、运行结果截图
    时间过了......

  • 相关阅读:
    C# 使用 Microsoft.Feeds 组件获取 RSS 全文
    使用 Jquery 做类似搜索引擎效果
    ASP.NET MVC 利用 IHttpModule 实现路由调试
    Python 爬虫类库 Selenium 的常用方法介绍
    C# 中 New 关键词的几种用法
    ASP.NET 使用 IIS URL Rewrite 模块实现伪静态
    Java 源码分析之 HashTable
    Java 类中代码块和构造方法的执行顺序
    C# 中使用 FFmpeg.NET
    C# 项目中使用 ServiceStack.Redis 操作 Redis
  • 原文地址:https://www.cnblogs.com/huangxing123/p/10345508.html
Copyright © 2011-2022 走看看