算法题:最大出牌数量(某厂2023笔试题)

最近遇到的一个算法题,在这里记录一下找到的答案。

完整题目:

手里给一副手牌,数字从0-9,有r(红色),g(绿色),b(蓝色),y(黄色)四种颜色,出牌规则为每次打出的牌必须跟上一张的数字或者颜色相同,否则不能连续出牌。

例如,手中有红色3,那么下次出牌可以出任意花色的3,或任意数字的红色牌,直至手中所有牌与上次出牌花色和数字都不匹配为止。

求可打出牌的最大数量。

输入第一行为手中牌面数字n (1<=n<=9),如

[1, 4, 3, 4, 5, 4]

输入第二行为手中第一行输入的牌面所对应的花色(r,g,b,y四种颜色表示),如

['r', 'y', 'b', 'b', 'r', 'y']

第一行与第二行输入长度相等,且位置一一对应,手牌数量最大为10张,输出最大出牌数量。

示例说明:
如果打(1, r)-> (5, r),那么能打两张。
如果打(4, y) -> (4, y)-> (4, b) ->(3, b),那么能打四张。

# 回溯
def maxPoke(nums, colors):
    len_ = len(nums)
    # 记录用过的牌
    vis = [False] * len_

    def dfs(num, color):
        max_ = 0
        # 枚举获取每张牌作为第1 ~ len次出时可以打出的最大数量
        for i in range(len_):
            if vis[i]:
                continue
            n, c = nums[i], colors[i]
            # -1表示当前正在寻找第一张牌,任何花色和数字都可以
            if n == num or c == color or num == -1:
                vis[i] = True
                max_ = max(1 + dfs(n, c), max_)
                vis[i] = False
        return max_

    return dfs(-1, -1)


print(maxPoke(nums=[1, 4, 3, 4, 5, 4], colors=['r', 'y', 'b', 'b', 'r', 'y']))  # 4

参考:https://leetcode.cn/circle/discuss/tKWjyw/ 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我有明珠一颗

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值