LeetCode015:除自身以外数组的乘积

简介: LeetCode015:除自身以外数组的乘积

简说Python,号主老表,Python终身学习者,数据分析爱好者,从18年开始分享Python知识,原创文章227篇,写过Python、SQL、Excel入门文章,也写过Web开发、数据分析文章,老表还总结整理了一份2022Python学习资料和电子书资源,关注后私信回复:2022 即可领取。

image.png

一、写在前面

LeetCode 第十四题 除自身以外数组的乘积 传输门:LeetCode014 : 除自身以外数组的乘积

今天给大家分享的是LeetCode 数组与字符串 第十五题: 存在重复元素,为面试而生,期待你的加入。

“Use the utility in the API is recommended in the project. But if you use it in an interview, you will definitely fail .”


二、今日题目

给定一个整数数组,判断是否存在重复元素。
如果任何值在数组中出现至少两次,函数返回 true。
如果数组中每个元素都不相同,则返回 false。

示例:

输入: [1,2,3,1]
输出: true
输入: [1,2,3,4]
输出: false
输入: [1,1,1,3,3,4,3,2,4,2]
输出: true

三、 分析

这个题目,有点简单,根据题目可以得出很清晰的思路,一个列表,所有元素,有没有两个一样的元素,有就返回True,没有就返回False,我第一个脑子就是:把list转换成set,学过Python基础或者看过我总结的Python小知识的读者都知道,set集合是没有重复元素的列表,这样就简单了,直接比较set和list长度就好了,长度一样,说明没有重复元素,否者有,思路如下:

image.png

快夸我字好看~


四、解题

1. 第一眼想到的:

表面上看,时间复杂度:O(1)
空间复杂度,多用了一个set:O(n)
(1)代码

# 第一眼想到的
class Solution(object):
    def containsDuplicate(self, nums):
        """
        :type nums: List[int]
        :rtype: bool
        """
        # 转换为集合(set)
        set_test = set(nums)
        # 比较集合与原列表长度
        if len(set_test) == len(nums):
            return False
        return True

(2)提交结果

image.png

提交结果

测试数据:18组
运行时间:36ms
击败人百分比:87.52%

2.使用collection的Counter类

表面上看,好像也是,时间复杂度:O(1)
空间复杂度,多用了一个dict:O(n)
(1)代码

# 使用collection的Counter类
class Solution1(object):
    def containsDuplicate(self, nums):
        """
        :type nums: List[int]
        :rtype: bool
        """
        if nums == []:
            return False
        from collections import Counter
        # 计数,Counter函数返回值为字典
        # key : vaule = 列表元素 : 出现次数
        con = Counter(nums)
        if max(con.values()) > 1:
            return True
        return False

(2)提交结果

image.png

不理想

测试数据:18组
运行时间:56ms
击败人百分比:18.52%

3.自己动手

时间复杂度:O(n)
空间复杂度:O(1)
(1)代码

# 老实本分
class Solution2(object):
    def containsDuplicate(self, nums):
        """
        :type nums: List[int]
        :rtype: bool
        """
        if nums == []:
            return False
        # 1.遍历列表
        for i in nums:
            # 2.移除当前遍历元素
            nums.remove(i)
            # 3.判断还有没有该元素在list中
            if i in nums:
               return True
        return False

(2)运行结果

image.png

胎死腹中

五、疑惑

像这种简单题目,就要多想几种方法,把学到的都用上,巩固知识,这样才能学到更多东西,而不是,好简单啊,打会游戏去吧!
推荐极客时间一门算法学习课程,我利用平时吃饭时间现在学习到20讲了,视频课程,学起来更加容易,需要的同学现在扫码购买优惠30元,明天就恢复原价了。

思想很复杂,
实现很有趣,
只要不放弃,
终有成名日。
                  ---《老表打油诗》

六、结语

加我微信:zs820553471,备注:leetcode,加入专门的leetcode刷题交流群。
坚持 and 努力 : 终有所获。


相关文章
|
1天前
|
云安全 人工智能 自然语言处理
|
9天前
|
数据采集 人工智能 自然语言处理
Meta SAM3开源:让图像分割,听懂你的话
Meta发布并开源SAM 3,首个支持文本或视觉提示的统一图像视频分割模型,可精准分割“红色条纹伞”等开放词汇概念,覆盖400万独特概念,性能达人类水平75%–80%,推动视觉分割新突破。
649 56
Meta SAM3开源:让图像分割,听懂你的话
|
6天前
|
搜索推荐 编译器 Linux
一个可用于企业开发及通用跨平台的Makefile文件
一款适用于企业级开发的通用跨平台Makefile,支持C/C++混合编译、多目标输出(可执行文件、静态/动态库)、Release/Debug版本管理。配置简洁,仅需修改带`MF_CONFIGURE_`前缀的变量,支持脚本化配置与子Makefile管理,具备完善日志、错误提示和跨平台兼容性,附详细文档与示例,便于学习与集成。
319 116
|
5天前
|
人工智能 Java API
Java 正式进入 Agentic AI 时代:Spring AI Alibaba 1.1 发布背后的技术演进
Spring AI Alibaba 1.1 正式发布,提供极简方式构建企业级AI智能体。基于ReactAgent核心,支持多智能体协作、上下文工程与生产级管控,助力开发者快速打造可靠、可扩展的智能应用。
|
21天前
|
域名解析 人工智能
【实操攻略】手把手教学,免费领取.CN域名
即日起至2025年12月31日,购买万小智AI建站或云·企业官网,每单可免费领1个.CN域名首年!跟我了解领取攻略吧~
|
9天前
|
机器学习/深度学习 人工智能 自然语言处理
AgentEvolver:让智能体系统学会「自我进化」
AgentEvolver 是一个自进化智能体系统,通过自我任务生成、经验导航与反思归因三大机制,推动AI从“被动执行”迈向“主动学习”。它显著提升强化学习效率,在更少参数下实现更强性能,助力智能体持续自我迭代。开源地址:https://github.com/modelscope/AgentEvolver
440 32
|
4天前
|
弹性计算 人工智能 Cloud Native
阿里云无门槛和有门槛优惠券解析:学生券,满减券,补贴券等优惠券领取与使用介绍
为了回馈用户与助力更多用户节省上云成本,阿里云会经常推出各种优惠券相关的活动,包括无门槛优惠券和有门槛优惠券。本文将详细介绍阿里云无门槛优惠券的领取与使用方式,同时也会概述几种常见的有门槛优惠券,帮助用户更好地利用这些优惠,降低云服务的成本。
272 132

热门文章

最新文章