云计算百科
云计算领域专业知识百科平台

练习集 谁先倒

 题目      

        划拳是古老中国酒文化的一个有趣的组成部分。酒桌上两人划拳的方法为:每人口中喊出一个数字,同时用手比划出一个数字。如果谁比划出的数字正好等于两人喊出的数字之和,谁就输了,输家罚一杯酒。两人同赢或两人同输则继续下一轮,直到唯一的赢家出现。

       下面给出甲、乙两人的酒量(最多能喝多少杯不倒)和划拳记录,请你判断两个人谁先倒。

输入格式:

        输入第一行先后给出甲、乙两人的酒量(不超过100的非负整数),以空格分隔。下一行给出一个正整数N(≤100),随后N行,每行给出一轮划拳的记录,格式为:

甲喊 甲划 乙喊 乙划

        其中喊是喊出的数字,划是划出的数字,均为不超过100的正整数(两只手一起划)。

输出格式:

       在第一行中输出先倒下的那个人:A代表甲,B代表乙。第二行中输出没倒的那个人喝了多少杯。题目保证有一个人倒下。注意程序处理到有人倒下就终止,后面的数据不必处理。

输入样例:

1 1
6
8 10 9 12
5 10 5 10
3 8 5 12
12 18 1 13
4 16 12 15
15 1 1 16

输出样例:

A
1

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

栈限制

8192 KB

思路

        这是一道超级简单的算法题,跟着我的思路,一步一步来解决。

1.输入

       先后输入甲乙两人的酒量。输入划拳的轮数。最后输入每轮的记录,(有n轮,所以要用到for循环)注意不要把顺序搞反,按照甲喊 甲划 乙喊 乙划 的顺序。(要想到用Scanner或者BufferedReader从键盘中输入数据。这里用Scanner作为示例)

2.判断

        判断谁比划出的数字正好等于两人喊出的数字之和,谁就输了,输家罚一杯酒。注意:当两人同时输时就进行下一轮,两人都不喝酒。分别判断两人的喝酒数是否大于两人的酒量。优先大于的一人先倒下。

3.输出

       在第一行中输出先倒下的那个人:A代表甲,B代表乙。第二行中输出没倒的那个人喝了多少杯。

代码

import java.util.Scanner;

public class Main {
public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        // 读取甲、乙的酒量
        int aCapacity = sc.nextInt();
        int bCapacity = sc.nextInt();
        // 读取划拳轮数
        int n = sc.nextInt();
        
        int aDrink = 0; // 甲喝的杯数
        int bDrink = 0; // 乙喝的杯数
        
        for (int i = 0; i < n; i++) {
            // 读取本轮划拳数据:甲喊、甲划、乙喊、乙划
            int aCall = sc.nextInt();
            int ahua = sc.nextInt();
            int bCall = sc.nextInt();
            int bhua = sc.nextInt();
            
            // 计算两人喊出的数字之和
            int sumCall = aCall + bCall;
            
            // 判断甲、乙是否输(划的数字等于和)等号成立则为true
            boolean aLose = (ahua == sumCall);
            boolean bLose = (bhua == sumCall);
            
            // 因为只有一人输时才喝酒,所以我们得判断甲乙两人有没有同时输。
            if (aLose && !bLose) {
                aDrink++;//甲输乙赢
            } else if (!aLose && bLose) {
                bDrink++;//甲赢乙输
            }
            
            // 检查是否有人倒下
            if (aDrink > aCapacity) {
                System.out.println("A");
                System.out.println(bDrink);
                return;//要求换行
            }
            if (bDrink > bCapacity) {
                System.out.println("B");
                System.out.println(aDrink);
                return;
            }
        }
    }
}

       是一个刚开始学习算法的小白⌯˃̶ᗜ˂̶⌯ಣ

        如果思路或代码有不对的地方请大神们多多赐教ദ്ദി˶>ᴗo)✧

 

 

赞(0)
未经允许不得转载:网硕互联帮助中心 » 练习集 谁先倒
分享到: 更多 (0)

评论 抢沙发

评论前必须登录!