PAT 1046 划拳
来源:互联网 发布:剑灵人物数据 编辑:程序博客网 时间:2024/05/21 18:40
划拳是古老中国酒文化的一个有趣的组成部分。酒桌上两人划拳的方法为:每人口中喊出一个数字,同时用手比划出一个数字。如果谁比划出的数字正好等于两人喊出的数字之和,谁就赢了,输家罚一杯酒。两人同赢或两人同输则继续下一轮,直到唯一的赢家出现。
下面给出甲、乙两人的划拳记录,请你统计他们最后分别喝了多少杯酒。
输入格式:
输入第一行先给出一个正整数N(<=100),随后N行,每行给出一轮划拳的记录,格式为:
甲喊 甲划 乙喊 乙划
其中“喊”是喊出的数字,“划”是划出的数字,均为不超过100的正整数(两只手一起划)。
输出格式:
在一行中先后输出甲、乙两人喝酒的杯数,其间以一个空格分隔。
输入样例:
5
8 10 9 12
5 10 5 10
3 8 5 12
12 18 1 13
4 16 12 15
输出样例:
1 2
//以下为解:#include<stdio.h>int main(void){ int J_han,J_hua,Y_han,Y_hua,N,J_number=0,Y_number=0; scanf("%d",&N); while(N--) //注意点1 { scanf("%d %d %d %d",&J_han,&J_hua,&Y_han,&Y_hua);//注意点2 if((J_han+Y_han==J_hua)&&(J_han+Y_han!=Y_hua)) //甲赢且乙没有赢,乙喝 ++Y_number; else if((J_han+Y_han==Y_hua)&&(J_han+Y_han!=J_hua)) //乙赢且甲没有赢,甲喝 ++J_number; else; //同赢或同输,不计 } printf("%d %d\n",J_number,Y_number);}
注意点1:
while(N–) {……}
可以记住的是一种对应于题中要求的输入方法的解决方法:
题目中要求的输入方法是:一次性输入以下数据,然后才允许输出,而不是先输入一组数据,然后按下\n输出一组数据结果,再输入一组数据,然后输出一组数据结果,即一次性输入以下的数据:
5
8 10 9 12
5 10 5 10
3 8 5 12
12 18 1 13
4 16 12 15
然后输出结果:
1 2
//所以,对应这种输入格式,采用的完整的输入方法为:scanf("……"); //承接 数据N(也就是5)while(N--){ scanf("%d %d %d %d",&J_han,&J_hua,&Y_han,&Y_hua); …… …… } //注意是 N--,而不是--N
注意点2:
//此处采用以下形式也可以,但是很麻烦 int n=0; while(scanf("%d %d %d %d",&J_han,&J_hua,&Y_han,&Y_hua)!=0){ ++n; if(n==N) break; …… …… }也可以,但是费力,以上方法适用于输入一行数据,立即出一结果,在输入一行数据,然后再出结果的方式,注意与本种输入需求相区别
阅读全文
0 0
- PAT-1046划拳
- 1046,划拳,PAT
- PAT乙级1046 划拳
- PAT 1046划拳
- PAT 1046 划拳
- PAT 1046 划拳
- PAT[1046]划拳
- PAT-1046(划拳)
- PAT(basic level) 1046 划拳(15)
- 【PAT】1046. 划拳(15)
- PAT-B 1046. 划拳
- PAT-B 1046. 划拳
- PAT B1046. 划拳(15)
- [PAT-乙级]1046.划拳
- 1046. 划拳(15) PAT
- PAT:B1046. 划拳(15)
- 1046].划拳
- 1046 划拳
- 垃圾收集器与内存分配策略
- 10018---Spring IOC和AOP 原理彻底搞懂
- 关于远程桌面的参数问题
- 对数组进行重新排序
- Android 一个TextView中设置文字不同字体大小和颜色的最完整方法
- PAT 1046 划拳
- 百度之星资格赛1003 完全背包
- 百度之星1003度度熊与邪恶大魔王
- Python文本挖掘:词云图
- 百度之星资格赛1004 01背包+记录路径套路
- Delphi程序点与面的结合应用你不能错过这次交集的机会
- 前端js+后端php进行图片压缩上传(解决move_uploaded_file失败并附源码)
- 【Machine Learning】笔记:Adaptive learning rates
- LeetCode 312. Burst Balloons(戳气球)