poker-hands
Quickly evaluate poker hands.
Rules
In the card game poker, a hand consists of five cards and are ranked, from lowest to highest, in the following way:
- High Card: Highest value card.
- One Pair: Two cards of the same value.
- Two Pairs: Two different pairs.
- Three of a Kind: Three cards of the same value.
- Straight: All cards are consecutive values.
- Flush: All cards of the same suit.
- Full House: Three of a kind and a pair.
- Four of a Kind: Four cards of the same value.
- Straight Flush: All cards are consecutive values of same suit.
- Royal Flush: Ten, Jack, Queen, King, Ace, in same suit.
The cards are valued in the order:
- 2, 3, 4, 5, 6, 7, 8, 9, 10, Jack, Queen, King, Ace.
Install
$ npm install poker-hands
var poker = require('poker-hands');
Usage
A hand is represented as a string of 5 pairs of characters. For example:
'5H 5C 6S 7S KD'
'2C 3S 8S 8D TD'
.judgeWinner([hand, hand])
Given a tuple of two hands, return the index of the stronger hand.
poker.judgeWinner(['5H 5C 6S 7S KD', '2C 3S 8S 8D TD']);
poker.judgeWinner(['5D 8C 9S JS AC', '2C 5C 7D 8S QH']);
poker.judgeWinner(['2D 9C AS AH AC', '3D 6D 7D TD QD']);
poker.judgeWinner(['4D 6S 9H QH QC', '3D 6D 7H QD QS']);
poker.judgeWinner(['2H 2D 4C 4D 4S', '3C 3D 3S 9S 9D']);
.highestCard(hand)
Return an array of the cards' values, sorted strongest to weakest.
poker.highestCards('5D AC JS 8C 9S');
poker.highestCards('2C 5C 7D 8S QH');
.hasPair(hand)
If the hand has a pair, return the value of the pair, otherwise return undefined
.
poker.hasPair('5H 5C 6S 7S KD');
poker.hasPair('2C 3S 8S 8D TD');
poker.hasPair('2C 5C 7D 8S QH');
.hasTwoPairs(hand)
If the hand has a two pairs, return an array of the values of the pairs with the strongest first, otherwise return undefined
.
poker.hasTwoPair('3H 9C 9S 2D 3D');
poker.hasTwoPair('7S 8H 8C KH KS');
poker.hasTwoPair('5H 5C 6S 7S KD');
.hasThreeOfAKind(hand)
If the hand has a three of a kind, return the value of the three of a kind, otherwise return undefined
.
poker.hasThreeOfAKind('3H 9C 9S 2D 9D');
poker.hasThreeOfAKind('7S 8H 8C KH KS');
.hasStraight(hand)
If the hand has a straight, return the highest value in the straight, otherwise return undefined
.
poker.hasStraight('8D 6C 5S 7H 4S');
poker.hasStraight('7S 8H 8C KH KS');
.hasFlush(hand)
If the hand has a flush, return the suit of the flush, otherwise return undefined
.
poker.hasFlush('3D 6D 7D TD QD');
poker.hasFlush('7S 8H 8C KH KS');
.hasFullHouse(hand)
If the hand has a full house, return the value of the three of a kind, otherwise return undefined
.
poker.hasFullHouse('2H 2D 4C 4D 4S');
poker.hasFullHouse('3C 3D 3S 9S 9D');
.hasFourOfAKind(hand)
If the hand has a four of a kind, return the value of the four of a kind, otherwise return undefined
.
poker.hasFourOfAKind('9D 9S KH 9H 9C');
poker.hasFourOfAKind('3H 7C 7S 2D 7D');
.hasStraightFlush(hand)
If the hand has a straight flush, return the highest value in the straight, otherwise return undefined
.
poker.hasStraightFlush('4H 3H 6H 5H 7H');
poker.hasStraightFlush('9D 9S KH 9H 9C');
.hasRoyalFlush(hand)
Return a boolean for if the hand has a royal flush.
poker.hasRoyalFlush('AD KD JD QD TD');
poker.hasRoyalFlush('4D 7D KD QD 2D');
Tests
To run the test suite, first install the dependencies, then run npm test
:
$ npm install
$ npm test