我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Python里面如何从一道简单算法题里面解释什么叫做 O(1)

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Python里面如何从一道简单算法题里面解释什么叫做 O(1)

这期内容当中小编将会给大家带来有关Python里面如何从一道简单算法题里面解释什么叫做 O(1),文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

 Python里面如何从一道简单算法题里面解释什么叫做 O(1)

今天有同学在粉丝群里面问了一个算法题:

Python里面如何从一道简单算法题里面解释什么叫做 O(1)

对话中的题目如下:

Python里面如何从一道简单算法题里面解释什么叫做 O(1)

题目要求从一个有序数组 nums 中,原地删除重复出现的元素,使得每个元素只出现一次。返回删除后数组的长度。不能使用额外的数组空间,使用  O(1)空间复杂度。

这个同学之所以做错了,是因为他没有理解什么叫做  O(1)空间复杂度。他在第3行实际上生成了一个新的列表。这个列表的长度取决于原来列表的长度,原来列表不重复的元素越多,这个新的列表也就越长,所以它的空间复杂度是  O(n)。而且题目要求“原地”修改原来的列表,而不是生成新的列表。

我们先说说什么叫做O(1)空间复杂度。它不是指只能申请1个变量,而是指你额外申请的变量数量是恒定的,不会根据输入列表元素的数量而变化。所以,即使你申请1万个变量,但无论输入的原列表有1个元素还是1亿个元素,你始终只使用这1万个变量,那么也可以说空间复杂度为  O(1)。

再来说说什么叫做原地修改。这就是说,你直接修改输入的列表,不额外使用新的列表。我们知道,在 Python  里面,向列表里面添加一个元素使用xxx.append(yy),从列表里面根据索引删除一个元素xxx.pop(index),都是原地修改。

回到这道题目,这道题属于 LeetCode 上面简单级别的题目,如果要应聘好一些的互联网公司,这种题目应该能做到信手拈来。

这道题的关键,在于原来的列表是有序列表,所以重复的数字一定是连在一起的。因此,  我们只需要逐一检查当前元素跟上一个元素是否相同,如果相同,就移除当前元素,如果不同,就检查下一个元素。

因此,我们来写代码:

class Solution:     def removeDuplicates(self, nums):         if not nums:             return 0         last = None         index = 0         length = len(nums)         while index < length:             ele = nums[index]             if index == 0:                 last = ele                 index = 1             elif ele == last:                 length -= 1                 nums.pop(index)             else:                 last = ele                 index += 1         return length

运行效果如下图所示:

Python里面如何从一道简单算法题里面解释什么叫做 O(1)

需要注意的是,这道题的时间复杂度是  O(n),因为从列表里面根据索引删除元素的时候,后面的元素会依次向前移动一位。一般来说,时间复杂度和空间复杂度是不能兼得的。你可以用空间换时间,也可能用时间换空间,但是很难做到同时又不占空间又不占时间。

上述就是小编为大家分享的Python里面如何从一道简单算法题里面解释什么叫做 O(1)了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Python里面如何从一道简单算法题里面解释什么叫做 O(1)

下载Word文档到电脑,方便收藏和打印~

下载Word文档

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录