鱼C论坛

 找回密码
 立即注册
查看: 2041|回复: 5

[已解决]长度大于5的单连牌

[复制链接]
发表于 2022-6-7 11:50:45 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 dianqi206 于 2022-6-13 19:23 编辑

【问题描述】
最佳答案
2022-6-7 14:08:41
思路:
设字典键 2 至 13,全部值初始为 False。
输入值同时将字典里对应的键,将值改成 True。
循环字典,假设遇到值是 True 加1,如果超过或等于 5 便输出键。

cards = list(map(int, input().split()))
nums = {key: True if key in cards else False for key in range(2, 14)}

res = 0
arr = []
temp = []

for each in nums.items():
        key, value = each
        if value:
                res += 1
                temp.append(key)
        else:
                if res >= 5:
                        arr.append(temp)
                temp = []
                res = 0

for each in arr:
        print(*each)

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-6-7 13:17:41 From FishC Mobile | 显示全部楼层
你的代码呢?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-6-7 14:01:43 | 显示全部楼层
你可以先利用set的特性先把数表去重 然后再循环 找到连续的就可以了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-6-7 14:08:41 From FishC Mobile | 显示全部楼层    本楼为最佳答案   
思路:
设字典键 2 至 13,全部值初始为 False。
输入值同时将字典里对应的键,将值改成 True。
循环字典,假设遇到值是 True 加1,如果超过或等于 5 便输出键。

cards = list(map(int, input().split()))
nums = {key: True if key in cards else False for key in range(2, 14)}

res = 0
arr = []
temp = []

for each in nums.items():
        key, value = each
        if value:
                res += 1
                temp.append(key)
        else:
                if res >= 5:
                        arr.append(temp)
                temp = []
                res = 0

for each in arr:
        print(*each)

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-6-7 14:09:09 | 显示全部楼层

等你写啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-6-7 14:09:53 From FishC Mobile | 显示全部楼层
wp231957 发表于 2022-6-7 14:09
等你写啊


想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-11 10:05

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表