123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 |
- package main
- import (
- "bufio"
- "fmt"
- "os"
- "sort"
- )
- type Game struct {
- Words map[string]*Word
- Length int
- }
- func NewGame() *Game {
- return &Game{
- Words: make(map[string]*Word),
- }
- }
- func (g Game) scoreWordsByCommonLetterLocations() error {
- letterIdxScores := make(map[int]map[string]int)
- var lastWord string
- for _, word := range g.Words {
- word.Score = 0
- lastWord = word.Word
- }
- for idx := range lastWord {
- letterIdxScores[idx] = make(map[string]int)
- }
- for _, word := range g.Words {
- for idx, letter := range word.Word {
- letterIdxScores[idx][string(letter)]++
- }
- }
- for _, word := range g.Words {
- for idx, letter := range word.Word {
- word.Score += letterIdxScores[idx][string(letter)]
- }
- }
- return nil
- }
- func (g Game) FilterWords(guess string, score int) {
- for _, word := range g.Words {
- if !word.MatchesGuess(guess, score) {
- delete(g.Words, word.Word)
- }
- }
- }
- func (g Game) getSortedScores() []string {
- var sortedWordScores []string
- for _, word := range g.Words {
- sortedWordScores = append(sortedWordScores, word.Word)
- }
- debugPrint("Sorted Word Scores: %v\n", sortedWordScores)
- // sort words by score
- sort.Slice(sortedWordScores, func(i, j int) bool {
- if g.Words[sortedWordScores[i]].Score != g.Words[sortedWordScores[j]].Score {
- return g.Words[sortedWordScores[i]].Score > g.Words[sortedWordScores[j]].Score
- }
- // sort by word if scores are equal - this is for consistent answers for unit testing
- return g.Words[sortedWordScores[i]].Word < g.Words[sortedWordScores[j]].Word
- })
- return sortedWordScores
- }
- func (g Game) getBestGuess() (string, error) {
- return g.getSortedScores()[0], nil
- }
- func (g Game) printSortedScores() (string, error) {
- sortedWordScores := g.getSortedScores()
- fmt.Println("\n>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>")
- fmt.Print("Words sorted by Score:\n")
- for _, word := range sortedWordScores {
- fmt.Printf("%s: %d\n", word, g.Words[word].Score)
- }
- fmt.Println("")
- return sortedWordScores[0], nil
- }
- func (g Game) getWordsFromStdin() error {
- fmt.Println("Enter Words, one per line. Enter a period to end input.")
- for {
- reader := bufio.NewReader(os.Stdin)
- word, _ := reader.ReadString('\n')
- word = word[:len(word)-1]
- if word == "." {
- fmt.Print("\nOK!\n\n")
- return nil
- }
- if g.Length == 0 {
- g.Length = len(word)
- } else {
- if len(word) != g.Length {
- fmt.Printf("Error: All words must be the same length (%d), skipping: %s\n", g.Length, word)
- continue
- }
- }
- g.Words[word] = &Word{Word: word}
- }
- }
|