解决leetcode第3934题最短唯一子数组

3934.最短唯一子数组

难度:困难

问题描述:

给你一个整数数组nums。

找出nums中与其他任何子数组均不相同的子数组的最小长度。返回一个整数,表示此类子数组的最小可能长度。

子数组是数组中的一个连续的非空元素序列。

如果两个子数组具有相同的长度,并且对应位置的元素也相同,则认为这两个子数组是相同的。

示例1:

输入:nums=3,3,3

输出:3

解释:

长度为1的子数组:3→出现3次

长度为2的子数组:3,3→出现2次

长度为3的子数组:3,3,3→出现1次

子数组3,3,3是唯一的,因此最小唯一子数组的长度为3。

示例2:

输入:nums=2,1,2,3,3

输出:1

解释:

长度为1的子数组:

2→出现2次

1→出现1次

3→出现2次

子数组1是唯一的,因此最小唯一子数组的长度为1。

示例3:

输入:nums=1,1,2,2,1

输出:2

解释:

长度为1的子数组:

1→出现3次

2→出现2次

长度为2的子数组:

1,1→出现1次

1,2→出现1次

2,2→出现1次

2,1→出现1次

至少有一个长度为2的子数组是唯一的,因此最小唯一子数组的长度为2。

提示:

1<=nums.length<=10**5

1<=numsi<=10**5

问题分析:

本问题首先要解决如何在一个整数数组nums中找出所有子数组的问题,函数get_all_sub_array(nums)实现了这一功能,其次是在这些子数组中找出只出现一次的子数组,这样就保证了这些找出的子数组具有唯一性,最后在这些具有唯一性的子数组中找出最短长度即为问题的解。

程序如下:

python 复制代码
#找出一个数组nums中所有的子数组并返回
def get_all_sub_array(nums):
    n=len(nums)
    a=[]
    for i in range(n):
        for j in range(i+1,n+1):
            b=nums[i:j]
            a.append(b)
    return a

#主程序
nums=eval(input('pls input nums='))
t=get_all_sub_array(nums)
b=[]
for i in t:
    if t.count(i)==1:
        b.append(i)
c=min(list(len(x) for x in b))
print(c)

运行实例一

pls input nums=1,2,3,3,4

1

运行实例二

pls input nums=1,2,1,2,2,3

1

运行实例三

pls input nums=2,3,2,3,2

3

相关推荐
ZhengEnCi4 小时前
P2M-Matplotlib折线图完全指南-从数据可视化到趋势分析的Python绘图利器
python·matlab·数据可视化
ZhengEnCi6 小时前
P2L-Matplotlib饼图完全指南-从数据可视化到图表定制的Python绘图利器
python·matlab
曲幽6 小时前
你的REST接口还在“过度投喂”数据吗?——FastAPI + GraphQL实战避坑指南
python·fastapi·web·graphql·route·cors·rest·strawberry
用户8358086187917 小时前
基于 Self-RAG 与列表级重排序的进阶 RAG 系统设计与实现
python
To_OC17 小时前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC17 小时前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
BadBadBad__AK19 小时前
线段树维护区间 k 次方和
c++·数学·算法·stl
Warson_L1 天前
Python `Annotated` 与 LangGraph Reducer 学习笔记
python
韩师傅1 天前
海天线算法的前世今生
python·计算机视觉
韩师傅1 天前
当你的甲方设备过烂,要如何快速出效果?
python·计算机视觉