• java实现第三届蓝桥杯古代赌局


    古代赌局

    【编程题】(满分23分)

    俗话说:十赌九输。因为大多数赌局的背后都藏有阴谋。不过也不尽然,有些赌局背后藏有的是:“阳谋”。

    有一种赌局是这样的:桌子上放六个匣子,编号是1至6。多位参与者(以下称玩家)可以把任意数量的钱押在某个编号的匣子上。所有玩家都下注后,庄家同时掷出3个骰子(骰子上的数字都是1至6)。输赢规则如下:
    1. 若某一个骰子上的数字与玩家所押注的匣子号相同,则玩家拿回自己的押注,庄家按他押注的数目赔付(即1比1的赔率)。

    1. 若有两个骰子上的数字与玩家所押注的匣子号相同,则玩家拿回自己的押注,庄家按他押注的数目的2倍赔付(即1比2的赔率)。

    2. 若三个骰子上的数字都与玩家所押注的匣子号相同,则玩家拿回自己的押注,庄家按他押注的数目的6倍赔付(即1比6的赔率)。

    3. 若玩家所押注匣子号与某个骰子示数乘积等于另外两个骰子示数的乘积,则玩家拿回自己的押注,庄家也不赔付(流局)。

    4. 若以上规则有同时满足者,玩家可以选择对自己最有利的规则。规则执行后,则庄家收获所有匣子上剩余的押注。

    乍一看起来,好像规则对玩家有利,庄家吃亏。但经过大量实战,会发现局面很难说,于是怀疑是否庄家做了手脚,庄家则十分爽快地说:可以由玩家提供骰子,甚至也可以由玩家来投掷骰子。

    你的任务是:通过编程模拟该过程。模拟50万次,假定只有1个玩家,他每次的押注都是1元钱,其押注的匣子号是随机的。再假定庄家有足够的资金用于赔付。最后计算出庄家的盈率(庄家盈利金额/押注总金额)。

    【输入、输出格式要求】
    程序无输入,程序运行输出庄家的盈率,四舍五入保留到小数后3位。

    【注意】

    请仔细调试!您的程序只有能运行出正确结果的时候才有机会得分!

    请把所有类写在同一个文件中,调试好后,存入与【考生文件夹】下对应题号的“解答.txt”中即可。

    相关的工程文件不要拷入。

    请不要使用package语句。

    源程序中只能出现JDK1.5中允许的语法或调用。不能使用1.6或更高版本。

    public class Main {
        
        public boolean judge1(int[] A, int x) {
            for(int i = 0;i < A.length;i++)
                if(A[i] == x)
                    return true;
            return false;
        }
        
        public boolean judge2(int[] A, int x) {
            int count = 0;
            for(int i = 0;i < A.length;i++)
                if(A[i] == x)
                    count++;
            if(count >= 2)
                return true;
            return false;
        }
        
        public boolean judge3(int[] A, int x) {
            int count = 0;
            for(int i = 0;i < A.length;i++)
                if(A[i] == x)
                    count++;
            if(count == 3)
                return true;
            return false;
        }
        
        public boolean judge4(int[] A, int x) {
            if(x * A[0] == A[1] * A[2])
                return true;
            if(x * A[1] == A[0] * A[2])
                return true;
            if(x * A[2] == A[0] * A[1])
                return true;
            return false;
        }
        
        public void getResult() {
            double won = 0; 
            for(int i = 1;i <= 500000;i++) {
                int[] A = new int[3];
                for(int j = 0;j < 3;j++)
                    A[j] = (int) (Math.random() * 6) + 1;
                int x = (int) (Math.random() * 6) + 1;
                if(judge3(A, x)) {
                    won -= 6;
                    continue;
                } else if(judge2(A, x)) {
                    won -= 2;
                    continue;
                } else if(judge1(A, x)) {
                    won -= 1;
                    continue;
                } else if(!judge4(A, x))
                    won += 1;
            }
            won = won / 500000;
            System.out.printf("%.3f", won);
        }
        
        public static void main(String[] args) {
            Main test = new Main();
            test.getResult();
        }
    }
    
  • 相关阅读:
    HDU 1874 畅通工程续(dijkstra)
    HDU 2112 HDU Today (map函数,dijkstra最短路径)
    HDU 2680 Choose the best route(dijkstra)
    HDU 2066 一个人的旅行(最短路径,dijkstra)
    关于测评机,编译器,我有些话想说
    测评机的优化问题 时间控制
    CF Round410 D. Mike and distribution
    数字三角形2 (取模)
    CF Round410 C. Mike and gcd problem
    CF Round 423 D. High Load 星图(最优最简构建)
  • 原文地址:https://www.cnblogs.com/a1439775520/p/13076816.html
Copyright © 2020-2023  润新知