『ACM C++』 PTA 天梯赛练习集L1 | 018-020
终于一周有这么一天能够安静下来好好学习打打题,还是很美滋滋的哈哈~加油加油~
------------------------------------------------L1-018----------------------------------------------------------
大笨钟
微博上有个自称“大笨钟V”的家伙,每天敲钟催促码农们爱惜身体早点睡觉。不过由于笨钟自己作息也不是很规律,所以敲钟并不定时。一般敲钟的点数是根据敲钟时间而定的,如果正好在某个整点敲,那么“当”数就等于那个整点数;如果过了整点,就敲下一个整点数。另外,虽然一天有24小时,钟却是只在后半天敲1~12下。例如在23:00敲钟,就是“当当当当当当当当当当当”,而到了23:01就会是“当当当当当当当当当当当当”。在午夜00:00到中午12:00期间(端点时间包括在内),笨钟是不敲的。
下面就请你写个程序,根据当前时间替大笨钟敲钟。
输入格式:
输入第一行按照hh:mm的格式给出当前时间。其中hh是小时,在00到23之间;mm是分钟,在00到59之间。
输出格式:
根据当前时间替大笨钟敲钟,即在一行中输出相应数量个Dang。如果不是敲钟期,则输出:
Only hh:mm. Too early to Dang.
其中hh:mm是输入的时间。
输入样例1:
:
输出样例1:
DangDangDangDangDangDangDangDang
输入样例2:
:
输出样例2:
Only :. Too early to Dang.
------------------------------------------------L1-018----------------------------------------------------------
注解:这道题难度不大,思路还是蛮清晰的,就是很容易跳坑,刚开始用整型去存,发现出了点问题,对于整型无法直接接受像01,08,09这样的数字,所以第二次我换用char来处理了,需要注意的是对于24点和12点的特判问题。
#include<stdio.h> char data[];
int main()
{
for(int i = ;i<;i++) scanf("%c",&data[i]);
if(data[] == '' && data[] >'')
{
for(int i = ;i<data[]-''-;i++) printf("Dang");
if(data[] == data[] && data[] == '') return ;
else printf("Dang");
}
else if(data[] == '' && data[] == '')
{
if(data[] == data[] && data[] == '')
{
printf("Only %c%c:%c%c. Too early to Dang.",data[],data[],data[],data[]);
return ;
}
else printf("Dang");
}
else if(data[] == '' && data[] <='')
{
if(data[] == '')
{
printf("Only 00:00. Too early to Dang.");
return ;
}
for(int i = ;i<data[]-''+;i++) printf("Dang");
if(data[] == data[] && data[] == '') return ;
else printf("Dang");
}
else printf("Only %c%c:%c%c. Too early to Dang.",data[],data[],data[],data[]);
return ;
}
------------------------------------------------L1-019----------------------------------------------------------
谁先倒
划拳是古老中国酒文化的一个有趣的组成部分。酒桌上两人划拳的方法为:每人口中喊出一个数字,同时用手比划出一个数字。如果谁比划出的数字正好等于两人喊出的数字之和,谁就输了,输家罚一杯酒。两人同赢或两人同输则继续下一轮,直到唯一的赢家出现。
下面给出甲、乙两人的酒量(最多能喝多少杯不倒)和划拳记录,请你判断两个人谁先倒。
输入格式:
输入第一行先后给出甲、乙两人的酒量(不超过100的非负整数),以空格分隔。下一行给出一个正整数N(≤100),随后N行,每行给出一轮划拳的记录,格式为:
甲喊 甲划 乙喊 乙划
其中喊是喊出的数字,划是划出的数字,均为不超过100的正整数(两只手一起划)。
输出格式:
在第一行中输出先倒下的那个人:A代表甲,B代表乙。第二行中输出没倒的那个人喝了多少杯。题目保证有一个人倒下。注意程序处理到有人倒下就终止,后面的数据不必处理。
输入样例:
输出样例:
A
------------------------------------------------L1-019----------------------------------------------------------
注解:水题,难度不大,注意一下函数判断位置就好
#include<stdio.h> int max_a,max_b,times;
int call_a,call_b,out_a,out_b;
int temp_a,temp_b;
int main()
{
scanf("%d %d %d",&max_a,&max_b,×);
temp_a = temp_b = ;
for(int i = ;i<times;i++)
{
scanf("%d %d %d %d",&call_a,&out_a,&call_b,&out_b);
int sum = call_a + call_b;
if(out_a == sum && out_b == sum) continue;
else
{
if(out_a == sum) temp_a++;
if(out_b == sum) temp_b++;
}
if(temp_a > max_a)
{
printf("A\n%d\n",temp_b);
break;
}
if(temp_b > max_b)
{
printf("B\n%d\n",temp_a);
break;
}
}
return ;
}
------------------------------------------------L1-020----------------------------------------------------------
帅到没朋友
当芸芸众生忙着在朋友圈中发照片的时候,总有一些人因为太帅而没有朋友。本题就要求你找出那些帅到没有朋友的人。
输入格式:
输入第一行给出一个正整数N(≤100),是已知朋友圈的个数;随后N行,每行首先给出一个正整数K(≤1000),为朋友圈中的人数,然后列出一个朋友圈内的所有人——为方便起见,每人对应一个ID号,为5位数字(从00000到99999),ID间以空格分隔;之后给出一个正整数M(≤10000),为待查询的人数;随后一行中列出M个待查询的ID,以空格分隔。
注意:没有朋友的人可以是根本没安装“朋友圈”,也可以是只有自己一个人在朋友圈的人。虽然有个别自恋狂会自己把自己反复加进朋友圈,但题目保证所有K超过1的朋友圈里都至少有2个不同的人。
输出格式:
按输入的顺序输出那些帅到没朋友的人。ID间用1个空格分隔,行的首尾不得有多余空格。如果没有人太帅,则输出No one is handsome。
注意:同一个人可以被查询多次,但只输出一次。
输入样例1:
输出样例1:
输入样例2:
输出样例2:
No one is handsome
------------------------------------------------L1-020----------------------------------------------------------
注解:这道题思路简单,建一个超过五位数的数组去存放已有的数据即可,如find[100000];。然后这道题有一个重点需要注意,那就是对最后结果的处理:
%Nd -> 表示输出的整型宽度至少为N位,右对齐,位数大于5则输出实际位数. 如:printf("%5d",1) 输出: 1(不足用空格填充);
%0Nd -> 表示输出的整型宽度至少为N位,不足N位用0填充. 如: printf("%05d",1) 输出:00001;
AC代码:
#include<stdio.h> int times,friends,ans;
int find[];
int main()
{
scanf("%d",×);
ans = ;
for(int i = ;i<times;i++)
{
scanf("%d",&friends);
for(int u = ;u<friends;u++)
{
int temp;
scanf("%d",&temp);
if(friends != ) find[temp]++;
}
}
scanf("%d",×);
for(int i = ;i<times;i++)
{
scanf("%d",&friends);
if(find[friends] == )
{
find[friends] = -;
if(ans != ) printf(" ");
printf("%05d",friends);
ans++;
}
}
if(ans == ) printf("No one is handsome");
return ;
}
注:如果有更好的解法,真心希望您能够评论留言贴上您的代码呢~互相帮助互相鼓励才能成长鸭~~
『ACM C++』 PTA 天梯赛练习集L1 | 018-020的更多相关文章
- 『ACM C++』 PTA 天梯赛练习集L1 | 001-006
应师兄要求,在打三月底天梯赛之前要把PTA上面的练习集刷完,所以后面的时间就献给PTA啦~ 后面每天刷的题都会把答案代码贡献出来,如果有好的思路想法也会分享一下~ 欢迎大佬提供更好的高效率算法鸭~ - ...
- 『ACM C++』 PTA 天梯赛练习集L1 | 052-053
今日刷题,水题水题 ------------------------------------------------L1-052------------------------------------ ...
- 『ACM C++』 PTA 天梯赛练习集L1 | 048-49
今日刷题048-049 ------------------------------------------------L1-048---------------------------------- ...
- 『ACM C++』 PTA 天梯赛练习集L1 | 040-41
近期安排 校赛3.23天梯赛3.30华工校赛 4.21省赛 5.12 ------------------------------------------------L1-040----------- ...
- 『ACM C++』 PTA 天梯赛练习集L1 | 021-024
忙疯警告,这两天可能进度很慢,下午打了一下午训练赛,训练赛的题我就不拿过来的,pta就做了一点点,明天又是满课的一天,所以进度很慢啦~ -------------------------------- ...
- 『ACM C++』 PTA 天梯赛练习集L1 | 007-011
真的是忙头晕了,学业.ACM打题.班级活动.自学新东西,哇这充实的大学~ ------------------------------------------------L1-007--------- ...
- 『ACM C++』 PTA 天梯赛练习集L1 | 044-45
记录今日刷题 ------------------------------------------------L1-044--------------------------------------- ...
- 『ACM C++』 PTA 天梯赛练习集L1 | 042-43
记录刷题情况 ------------------------------------------------L1-042--------------------------------------- ...
- 『ACM C++』 PTA 天梯赛练习集L1 | 036-037
这几天比较忙,所以随便做做水题了,得赶紧把英剧搞完啊啊啊啊啊啊 ------------------------------------------------L1-036-------------- ...
- 『ACM C++』 PTA 天梯赛练习集L1 | 029-033
哈哈,今天开始我也是学车人了~ 开始一千多道疯狂刷题~ ------------------------------------------------L1-029------------------ ...
随机推荐
- ioctl
在驱动程序里, ioctl() 函数上传送的变量 cmd 是应用程序用于区别设备驱动程序请求处理内容的值. cmd除了可区别数字外,还包含有助于处理的几种相应信息. cmd的大小为 32位,共分 4 ...
- Android开发如何定制framework层服务
刚刚跨完年,新年第一篇文章,那么今天将对Android开发framework中间层的服务定制使用作个总结.首先我们先导入Android平台源码framework层的代码到开发工具eclipse中,代码 ...
- JMeter测试WEB性能入门
一.JMeter介绍 1.Apache JMeter是什么 Apache JMeter 是Apache组织的开放源代码项目,是一个100%纯Java桌面应用,用于压力测试和性能测量.它最初被设计用于W ...
- ubuntu下面解压tar.gz包报错:tar命令报错: gzip: stdin: not in gzip format tar: Child returned status 1 tar: Error
原因: 压缩包文件不完整(损坏或者其他原因) 比如今天下载的tomcat8,使用ubuntu的命令下载的 curl -O http://apache.mirrors.ionfish.org/tomca ...
- netstat 检测及监测网络连接
网站没有很多流量,可查带宽却跑了几十M? 这是什么情况呢? 如果是出现这种情况,不排除是被CC了的可能.那么如何确定是否真的被CC了,被CC又有什么对应政策呢? netstat -na ,用 ...
- java字节码文件指令集
网上找的没有指令码这列 自己把它加上 更方便查阅 指令从0x00-0xc9 没有0xba 常量入栈指令 指令码 操作码(助记符) 操作数 描述(栈指操作数栈) 0x01 aconst_null nu ...
- 二、WPF datagrid 行变色
public void Color(){ DataGridRow row1 = (DataGridRow)this.dgSource.ItemContainerGenerator.ContainerF ...
- [翻译] JHChainableAnimations
JHChainableAnimations - (void)animationType_01 { /* * 缩放到0.8倍(执行spring动画效果的缩放)持续时间0.5s,完成了之后移动100的距离 ...
- Excel英语成绩单
- 枚举类型与位域枚举Enum
一.概述 定义一个值类型,其中包含固定值集合.枚举类型变量可以是此集合中的任意一个或多个值.枚举使用enum关键字来声明,与类同级.枚举本身可以有修饰符,但枚举的成员始终是公共的,不能有访问修饰符.枚 ...