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("\n");
break;
}
//如果列数小于 a/2(中心列),则输出空格
else{
printf(" ");
}
}
//如果转换为等效列的列数yemp2大于等于行数yemp1,则输出字符
else{
printf("%c",ch);
}
//末尾列换行
if(j==a-1){
printf("\n");
}
}
}
//输出多余的符号
printf("%d\n",number-temp);
}
思路
第一步:定义变量
第二步:因为跟以前的倒三角类似,所以运用了类似的方法;
第三步:运用while语句
第四步:打印输出

三.本题调试过程碰到问题及解决办法
跟以前的倒三角类似,所以运用了类似的方法,然后参考别人的才做出来
4、运行结果截图
时间过了......
PTA寒假一的更多相关文章
- pta寒假作业3
题目三:捉老鼠啊,亏了还是赚了 实验代码 #include <stdio.h> #include <stdlib.h> int main(void) { ...
- pta寒假作业2
题目二币值转换 题目代码 #include<stdio.h> int main (void) { int n, initial_n; scanf("%d", & ...
- PTA寒假三
抓老鼠啊~亏了还是赚了? (20 分) 某地老鼠成灾,现悬赏抓老鼠,每抓到一只奖励10元,于是开始跟老鼠斗智斗勇:每天在墙角可选择以下三个操作:放置一个带有一块奶酪的捕鼠夹(T),或者放置一块奶酪(C ...
- PTA寒假二
7-1 币值转换 (20 分) 输入一个整数(位数不超过9位)代表一个人民币值(单位为元),请转换成财务要求的大写中文格式.如23108元,转换后变成"贰万叁仟壹百零捌"元.为了简 ...
- 2018秋寒假作业6—PTA编程总结3
1.实验代码 7-1 抓老鼠啊~亏了还是赚了? (20 分) 某地老鼠成灾,现悬赏抓老鼠,每抓到一只奖励10元,于是开始跟老鼠斗智斗勇:每天在墙角可选择以下三个操作:放置一个带有一块奶酪的捕鼠夹(T) ...
- 寒假pta一
打印沙漏 本题要求你写个程序把给定的符号打印成沙漏的形状.例如给定17个“*”,要求按下列格式打 ***** *** * *** ***** 所谓“沙漏形状”,是指每行输出奇数个符号:各行符号中心对齐 ...
- 寒假作业 pta编程总结3
实验代码: 某地老鼠成灾,现悬赏抓老鼠,每抓到一只奖励10元,于是开始跟老鼠斗智斗勇:每天在墙角可选择以下三个操作:放置一个带有一块奶酪的捕鼠夹(T),或者放置一块奶酪(C),或者什么也不放(X).捕 ...
- 寒假作业 pta编程总结2
实验代码: #include<stdio.h>#include<stdbool.h> void toNUM(int n);void toUNIT(int n); int mai ...
- 2018秋寒假作业5—PTA编程总结2
1.实验代码: 7-1 币值转换 (20 分) 输入一个整数(位数不超过9位)代表一个人民币值(单位为元),请转换成财务要求的大写中文格式.如23108元,转换后变成"贰万叁仟壹百零捌&qu ...
随机推荐
- POJ 2774 Long Long Message (二分 + Hash 求最长公共子串)题解
题意:求最长公共子串 思路:把两个串Hash,然后我们把短的作为LCS的最大可能值,然后二分长度,每次判断这样二分可不可以.判断时,先拿出第一个母串所有len长的子串,排序,然后枚举第二个母串len长 ...
- [CodeForces - 463B] Caisa and Pylons
题目链接:http://codeforces.com/problemset/problem/463/B 求个最大值 AC代码: #include<cstdio> #include<c ...
- 解决 ln -s 软链接产生的Too many levels of symbolic links错误
参考: ln -s 软链接产生Too many levels of symbolic links错误 解决 ln -s 软链接产生的Too many levels of symbolic links错 ...
- 剑指offer 02:替换空格
题目描述 请实现一个函数,将一个字符串中的每个空格替换成“%20”.例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy. 解题代码 public cla ...
- git修改本地和远程仓库名称的解决方法
说明:旧的仓库名称为mygit,新的仓库名称为Blog 1.修改远程仓库名称 在GitHub上进入要修改的仓库,找到settings,修改名称. 2.修改本地仓库名称 进入存放项目的目录,我的是/ho ...
- 纪念L.A. Zadeh教授
扎德教授永远活在我们心中 汪 培 庄 辽宁工程技术大学,智能工程与数学研究院,阜新,123000 摘要 全球科技工作者都在悼念扎德教授的逝世.本文对扎德创立模糊数学的历史意义,他与中国同仁的关系和影响 ...
- Linux进程间通信机制
Linux支持管道.信号.unix system V三种IPC(Inter-Process-Communication)机制.以下分别对三种机制加以简单介绍. 一.信号机制: 信号又称作软中断,用来通 ...
- 用Apache Ant在Weka中嵌入新算法
本文将介绍一种新的添加新的算法到Weka中的方法,国内的论坛基本都是通过IDE(Eclipse或NetBeans)编译,详细教程请见上一篇博客.经研究,发现国外的网站很流行用Ant这个方法,教程奉上. ...
- python dpkt SSL 流tcp payload(从三次握手开始到application data)和证书提取
# coding: utf-8 #!/usr/bin/env python from __future__ import absolute_import from __future__ import ...
- js利用sort()方法实现数组排序
1.number类型排序 let aa = [1,11,2,4,3] aa.sort() console.log(aa) //[1,11,2,3,4] aa.sort((a,b)=>a-b) c ...