【发布时间】:2017-02-22 07:53:21
【问题描述】:
我不确定这里的最佳行动方案是什么。对于每个玩家,我创建了一个包含公共牌和自己的牌的数组,我剩下要做的一件事就是评估结果。
我当然可以蛮力检查每七张牌的组合,但是 a) 这不会非常优雅和快速,并且 b) 我不知道如何处理平局,从那时起你必须看看剩下的高牌。
这里是小提琴,我已经使用了 document.write() 来做所有事情,用于测试目的:
https://jsfiddle.net/bjp11yjb/1/
如果有人能指出我正确的方向,而不会让我太困惑,我将不胜感激!
var suits = ['Clubs', 'Spades', 'Hearts', 'Diamonds'];
var ranks = ['2', '3', '4', '5', '6', '7', '8', '9', '10', 'Jack', 'Queen', 'King', 'Ace'];
var combinations = ['Royal Flush', 'Straight Flush', 'Four of a Kind', 'Full House', 'Flush', 'Straight', 'Three of a Kind', 'Two Pair', 'One Pair'];
var deck = [];
var players = [new Player(), new Player()];
var table = [];
function Player() {
this.hand = [];
this.result;
}
function Card(suit, rank) {
this.suit = suit;
this.rank = rank;
this.name = rank + ' of ' + suit;
}
function initDeck() {
deck = [];
for(var i = 0; i < 4; i++) {
for(var j = 0; j < 13; j++) {
deck.push(new Card(suits[i], ranks[j]));
}
}
}
function drawCard() {
var randNumber = Math.floor(Math.random() * deck.length);
var drawnCard = deck[randNumber];
deck.splice(randNumber, 1);
return drawnCard;
}
function dealCards() {
for(var i = 0; i < 2; i++) {
for(var j = 0; j < players.length; j++) {
var drawnCard = drawCard();
players[j].hand.push(drawnCard);
}
}
}
function flop() {
for(var i = 0; i < 3; i++) {
var drawnCard = drawCard();
table.push(drawnCard);
}
}
function turn() {
var drawnCard = drawCard();
table.push(drawnCard);
}
function river() {
var drawnCard = drawCard();
table.push(drawnCard);
}
function showDown() {
for(var i = 0; i < players.length; i++) {
evaluate(i);
document.write("<br>");
}
}
function evaluate(player) {
var totalHand = players[player].hand.concat(table);
for(var i = 0; i < totalHand.length; i++) {
}
}
initDeck();
dealCards();
document.write("Player 1: " + players[0].hand[0].name + ' and ' + players[0].hand[1].name + '<br>');
document.write("Player 2: " + players[1].hand[0].name + ' and ' + players[1].hand[1].name + '<br><br>');
flop();
document.write("Flop: " + table[0].name + ', ' + table[1].name + ' and ' + table[2].name + '<br>');
turn();
document.write("Turn: " + table[0].name + ', ' + table[1].name + ', ' + table[2].name + ' and ' + table[3].name + '<br>');
river();
document.write("River: " + table[0].name + ', ' + table[1].name + ', ' + table[2].name + ', ' + table[3].name + ' and ' + table[4].name + '<br>');
showDown();
【问题讨论】:
-
有人会否决此投票的任何特定原因?我认为这是一个巨大的问题。这里的简短回答是它需要大量代码。大约 10 年前,我在 Actionscript 中做到了这一点,这非常困难。没有什么是复杂得离谱的,我们只是没有意识到涉及到多少概念(例如,识别顺子、识别同花、知道哪手牌的排名更高等)
-
这是一个非常棒的问题,但是这个算法中涉及的代码量可能超出了 SO 的范围。
标签: javascript