1

我正在做这个练习,练习是这样说的:

*给定一个包含 3 名玩家之间的 1000 个随机二十一点手的输入文件(此处:blackjack.txt),计算所有游戏中任何玩家遇到的二十一点的数量。

二十一点被定义为任何花色的 A 和任何花色的 10 点牌(J、Q、K 或 10)。

输入文件如下所示:(作为示例)

4H 5C AD JH 9C 10H

这意味着玩家 1 有红桃 4 和梅花 5;玩家 2 有方块 A 和红心 J(算作二十一点);玩家 3 有梅花 9 和红心 10。

为了解决这个问题,我们知道有一个标准的 52 张牌组,每场新游戏都会重新洗牌。*

我认为我的方法是正确的,我的代码是正确的,但是我的答案失败了,任何提示,获得正确答案的建议

这是我的代码:

import java.io.*;

public class Problema16 {

    public static void main(String args[]) {
        File archivo = null;
        FileReader fr = null;
        BufferedReader br = null;
        int counter = 0;
        //int rest = 0;

        try {
            archivo = new File("C:\\Users\\\blackjack.txt");
            fr = new FileReader(archivo);
            br = new BufferedReader(fr);
            String linea;
            String[] linea2 = null;

            while ((linea = br.readLine()) != null) //System.out.println(linea);
            {
                linea2 = linea.split(" ");

                String a = (linea2[0]);
                String b = (linea2[1]);
                String c = (linea2[2]);
                String d = (linea2[3]);
                String e = (linea2[4]);
                String f = (linea2[5]);

                if ((a.startsWith("A") && (b.startsWith("J") || (b.startsWith("Q") || (b.startsWith("K") || (b.startsWith("10")))))) || ((a.startsWith("J") || (a.startsWith("Q") || (a.startsWith("K") || (a.startsWith("10"))))) && (b.startsWith("A")))) {
                    counter++;
                    //System.out.println(a + "" + b + "");
                } else if ((c.startsWith("A") && (d.startsWith("J") || (d.startsWith("Q") || (d.startsWith("K") || (d.startsWith("10")))))) || ((c.startsWith("J") || (c.startsWith("Q") || (c.startsWith("K") || (c.startsWith("10"))))) && (d.startsWith("A")))) {
                    counter++;
                    //System.out.println(c + "" + d + "");
                } else if ((e.startsWith("A") && (f.startsWith("J") || (f.startsWith("Q") || (f.startsWith("K") || (f.startsWith("10")))))) || ((e.startsWith("J") || (e.startsWith("Q") || (e.startsWith("K") || (e.startsWith("10"))))) && (f.startsWith("A")))) {
                    counter++;
                    //System.out.println(e + "" + f + "");
                } else {
                    //sobra++;
                }
            }

            System.out.println(counter);
            //System.out.println(sobra);

        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

这是在线练习1。我的答案是 119,但是是错误的。

4

3 回答 3

4

if使用所有大括号很难阅读您的每个条件,但看起来还可以。你的问题在于else if。玩家 #1 和玩家 #2(以及玩家 #3)可以同时拥有二十一点因为您的代码只会计算其中的 1 个。

放下else,你应该没问题。

您还可以稍微提高代码的可读性。一些指示:

  • 检查第 2 / 3 名玩家的手牌涉及与第一个相同的逻辑。使用循环。
  • 也许您可以计算手牌的价值并检查它是否等于 21,而不是显式检查特定的牌。将这个逻辑放在单独的方法中会很好。
  • 计算手牌价值的一种简单方法(假设输入总是合法的)是放下花色(因为它无关紧要)并使用预定义的地图来确定牌面价值(例如“J”=> 10、“A” - 11 等。 )
于 2011-05-24T23:56:37.513 回答
1

一个简短的 sed 命令来验证:

sed 's/[CDHS] / /g;s/[CDHS]\r$//g;s/[JKQ]/+/g;s/10/+/g;s/A/-/g;s/\(. .\)/[\1]/g;s/+ -/ * /g;s/- +/ * /g' blackjack.txt | grep " \* " | wc -l 
119 lines

删除颜色,将 JKQ10 组合到 +,A 到 -(有点多余),+- 和 -+ 到 *(BJ)。

多场比赛:

sed 's/[CDHS] / /g;s/[CDHS]\r$//g;s/[JKQ]/+/g;s/10/+/g;s/A/-/g;s/\(. .\)/[\1]/g;s/+ -/ * /g;s/- +/ * /g' blackjack.txt | grep " \*.*\* " 
[6 5] [ * ] [ * ]
[3 +] [ * ] [ * ]
[ * ] [ * ] [4 4]
[5 8] [ * ] [ * ]

4 次 2 次命中。119+4 = 123

模式匹配当然可以用于以类似的方式生成 java 解决方案。

于 2011-05-25T00:46:05.177 回答
0

我不喜欢你的做法。它太复杂了。我将创建一个具有值字段的 Card 类(带有一个采用 String 的构造函数,即在文件中找到的那些)。这样你就可以拿到每张 2 张牌并检查数值是否等于 21。

于 2011-05-25T00:08:40.157 回答