|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
【问题描述】
给定一个只包含自然数的列表nums。列表的度指的是任一元素出现频率的最大值。找出与nums 拥有相同大小的度的最短连续子列表。输出这个子列表的长度。
【输入形式】
一个列表,包括方括号,逗号分隔
【输出形式】
整数
【样例输入】
[1, 2, 2, 3, 1]
【样例输出】
2
【样例说明】
输入列表的度是2,因为元素1和2的出现频数最大,均为2。连续子列表里面拥有相同度的有如下所示:
[1, 2, 2, 3, 1], [1, 2, 2, 3], [2, 2, 3, 1], [1, 2, 2], [2, 2, 3], [2, 2]
最短连续子数组[2, 2]的长度为2,输出2.
我只能求出度,不能确定这个度的最短连续子列表
本帖最后由 qq1151985918 于 2021-4-19 02:46 编辑
- ##nums = [1,2,2,3,1]
- ##nums = [1,2,1,2,1,3]
- ##nums = [1,2,3,4,5,1,2,3,4,5]
- ##nums = [1,2,3,4,5,5,4,3,2,1]
- ##nums = [1,2,3,1,2,3,1,2,3]
- ##nums = [1,2,3,3,3,2,2,1,1,2]
- ##nums = [1,2,3,3,3,2,2,1,1,3]
- nums = eval(input("请输入数组:"))
- countsons = [nums.count(x) for x in nums]
- maxnums = max(countsons)
- maxson = [x for x in set(nums) if nums.count(x) == maxnums]
- if maxnums == 1:
- print(1,"-->",*[[i] for i in nums])
- else:
- data = []
- for i in maxson:
- a,b = 0,-1
- while True:
- if nums[a] == i:
- break
- else:
- a += 1
- while True:
- if nums[b] == i:
- break
- else:
- b -= 1
- if b == -1:
- data.append(nums[a:])
- else:
- data.append(nums[a:b+1])
-
- lenlists = [len(x) for x in data]
- mindata = min(lenlists)
- minlist = [x for x in data if len(x) == mindata]
- print(mindata,"-->",*minlist)
复制代码
|
|