码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 算法题:最大出牌数量


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

    完整题目:

    手里给一副手牌,数字从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),那么能打四张。

    1. # 回溯
    2. def maxPoke(nums, colors):
    3. len_ = len(nums)
    4. # 记录用过的牌
    5. vis = [False] * len_
    6. def dfs(num, color):
    7. max_ = 0
    8. # 枚举获取每张牌作为第1 ~ len次出时可以打出的最大数量
    9. for i in range(len_):
    10. if vis[i]:
    11. continue
    12. n, c = nums[i], colors[i]
    13. # -1表示当前正在寻找第一张牌,任何花色和数字都可以
    14. if n == num or c == color or num == -1:
    15. vis[i] = True
    16. max_ = max(1 + dfs(n, c), max_)
    17. vis[i] = False
    18. return max_
    19. return dfs(-1, -1)
    20. print(maxPoke(nums=[1, 4, 3, 4, 5, 4], colors=['r', 'y', 'b', 'b', 'r', 'y'])) # 4

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

  • 相关阅读:
    软航H5 PDF签章产品经nginx代理之后浏览器中PDF盖章时提示:签章失败:网络错误 的问题排查及解决办法
    Python学习----数据容器
    springboot2.7.10升级到3.0.8版本
    【23届秋招】0828-文远知行C++测试开发工程师笔试
    网易面试总结——面试案例5~面试案例8
    CTFshow,信息搜集:web4
    U盘文件损坏且无法读取?别着急,教你恢复的绝招!
    【微信小程序-初级】一些基础功能实现参考
    SveletJs学习——数据绑定
    面试系列Spring:Spring的事务传播
  • 原文地址:https://blog.csdn.net/m0_37738114/article/details/134018041
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号