解决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

相关推荐
Kobebryant-Manba3 分钟前
学习参数管理
pytorch·python·深度学习
是有头发的程序猿4 分钟前
竞品分析 + 用户洞察自动化|基于 item_review 评论接口 + 多 AI Agent 实现淘宝评论全量采集与智能分析(附python源码)
java·python·自动化
信看4 分钟前
Jetson Orin Quectel QMI 拨号上网
开发语言·python
小欣加油7 分钟前
Leetcode31 下一个排列
数据结构·c++·算法·leetcode·职场和发展
凤凰院凶涛QAQ10 分钟前
《Java版数据结构 & 集合类剖析》链表与LinkedList:节点手拉手,增删不用愁
java·数据结构·链表
骑士雄师15 分钟前
课程导航LangGraph核心概念
python
SilentSamsara18 分钟前
DuckDB + Python:嵌入式 OLAP 数据库的轻量分析实战
开发语言·数据库·python·微服务
_日拱一卒23 分钟前
LeetCode:39组合总和
java·算法·leetcode·职场和发展
无限进步_24 分钟前
【Linux】进程状态、僵尸与孤儿、进程调度
linux·运维·服务器·开发语言·数据结构·算法
爱上纯净的蓝天25 分钟前
30 分钟上手 AtomCode:用它写一个 Python 批量整理文件/改名/生成报告小工具(新手教程)
python·开源·自动化脚本·atomcode·ai 编码助手