牛客网 雀魂启动

package main

import (
	"bufio"
	"fmt"
	"os"
	"strconv"
	"strings"
)

func convInts(ss []string) []int {
	result := make([]int, len(ss))
	for i, v := range ss {
		res, err := strconv.ParseInt(v, 10, 64)
		if err != nil {
			panic(err)
		}

		result[i] = int(res)
	}

	return result
}

func check3s(cardMap map[int]int, remainCards int) bool {
	//fmt.Println(remainCards, cardMap)

	if remainCards == 0 {
		return true
	}
	for i := 1; i <= 9; i++ {
		cnt, ok := cardMap[i]
		if !ok || cnt == 0 {
			continue
		}

		//check 3
		if cnt >= 3 {
			cardMap[i] -= 3
			ok := check3s(cardMap, remainCards-3)
			cardMap[i] += 3
			if ok {
				return ok
			}
		}

		//check seq
		res1, _ := cardMap[i+1]
		res2, _ := cardMap[i+2]
		if res1 > 0 && res2 > 0 {
			cardMap[i]--
			cardMap[i+1]--
			cardMap[i+2]--
			ok := check3s(cardMap, remainCards-3)
			cardMap[i]++
			cardMap[i+1]++
			cardMap[i+2]++
			if ok {
				return ok
			}
		}
	}

	return false
}

func match(cards []int) []int {
	need := make([]int, 0)

	cardMap := make(map[int]int)
	appears := make(map[int]struct{})
	for _, v := range cards {
		cardMap[v]++
		appears[v] = struct{}{}
	}

	for i := 1; i <= 9; i++ {
		if res, ok := cardMap[i]; ok && res == 4 {
			continue
		}

		//fmt.Println("adding cards", cards, i, cardMap)

		cardMap[i]++
		appears[i] = struct{}{}
		for k := range appears {
			if cardMap[k] < 2 {
				continue
			}

			cardMap[k] -= 2
			ok := check3s(cardMap, 12)
			//fmt.Println("after", cardMap)
			cardMap[k] += 2
			if ok {
				need = append(need, i)
			}
		}

		cardMap[i]--
		if cardMap[i] == 0 {
			delete(cardMap, i)
			delete(appears, i)
		}
	}

	return need
}

func main() {
	rd := bufio.NewReader(os.Stdin)

	s, _ := rd.ReadString('\n')
	s = strings.TrimSpace(s)
	ss := strings.Split(s, " ")
	is := convInts(ss)

	if len(is) != 13 {
		panic(is)
	}

	need := match(is)
	if len(need) == 0 {
		fmt.Println("0")
	} else {
		for i := 0; i < len(need)-1; i++ {
			fmt.Printf("%d ", need[i])
		}
		fmt.Printf("%d\n", need[len(need)-1])
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值