-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhand.go
86 lines (75 loc) · 1.55 KB
/
hand.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
package larvis
import (
"fmt"
"strings"
)
const (
Hand1Wins = "Hand 1"
Hand2Wins = "Hand 2"
Tie = "Tie"
)
// The available symbols and their values.
var Symbols = map[string]int{
"2": 2,
"3": 3,
"4": 4,
"5": 5,
"6": 6,
"7": 7,
"8": 8,
"9": 9,
"T": 10,
"J": 11,
"Q": 12,
"K": 13,
"A": 14,
}
// Card represents a single playing card.
type Card struct {
Symbol rune
Value int
}
func createCard(symbol rune) (Card, error) {
if _, ok := Symbols[string(symbol)]; !ok {
return Card{}, fmt.Errorf("invalid card symbol %q", string(symbol))
}
return Card{
Symbol: symbol,
Value: Symbols[string(symbol)],
}, nil
}
func (c Card) String() string {
return string(c.Symbol)
}
// Hand represents a hand of cards.
type Hand []Card
func CreateHand(cards []rune) (Hand, error) {
if len(cards) != 5 {
return Hand{}, fmt.Errorf("invalid number of cards: %d", len(cards))
}
h := make(Hand, 0, 5)
symbols := make(map[rune]int)
for _, c := range cards {
card, err := createCard(c)
if err != nil {
return Hand{}, err
}
symbols[c]++
if symbols[c] > 4 {
return Hand{}, fmt.Errorf("the %q card repeats more than 4 times", string(c))
}
h = append(h, card)
}
return h, nil
}
func (h Hand) String() string {
var s strings.Builder
for _, c := range h {
s.WriteString(string(c.Symbol))
}
return s.String()
}
// implement sort.Interface
func (h Hand) Len() int { return len(h) }
func (h Hand) Less(i, j int) bool { return h[i].Value > h[j].Value } // Descending order.
func (h Hand) Swap(i, j int) { h[i], h[j] = h[j], h[i] }