任务二:删除排序数组中的重复项

原文链接:https://leetcode-cn.com/problems/remove-duplicates-from-sorted-array/

最开始的解决思路:

  遍历2次数组;

  第一次,遍历整个数组,放置标记index1

  第二次,从每一个第一次遍历的元素index1后面开始遍历index2.

  然后,一个一个比较,重复的元素,删除后来再次重复的元素index2。 

 for index1 in range(0, len( num_list) - 1):
for index2 in range(index1, len( num_list)):
if num_list[index1] == num_list[index2]:
del num_list[index2]

1.遇到的问题:每次del删除数组元素之后,数组本身以及数组长度发生变化,但是,for循环中的range()函数不会再次求值len(num_list)。

       导致,Num_list数组去重之后,缩短了,但是len(num_list)还是原来的长度。

       最终导致,数组越界异常。

 核心:数组可变,删除元素,导致数组长度变化。与遍历数组,冲突。

    解决方法:遍历比较功能,和删除元素功能分开。比较得到的重复元素,先进行标记,然后统一再删除。

 class Solution:
def removeDuplicates(self, origin_list):
length = len(origin_list)
print(origin_list)
#遍历比较
#先取出第一个元素
for index1 in range(0, length - 1):
#再取出第二个元素
for index2 in range(index1 + 1, length):
#比较index1元素和index2元素2,如果index2重复则删除
if origin_list[index1] == origin_list[index2]:
#不能删除,则对要删除元素做标记
origin_list[index2] = 'null'
print(origin_list)
#删除所有null值元素
for ele in origin_list:
if ele == 'null':
origin_list.remove('null') new_length = len(origin_list)
return origin_list

2.遇到的问题: 

1         for ele in origin_list:
2 if ele == 'null':
3 origin_list.remove('null')

    这段代码,无法将origin_list列表中的重复值全部去除,

    原因:列表在remove时,本身发生了变化。列表的刚刚索引,也发生了变化。

    解决方法:使用while循环:

 while 'null' in num_list:
num_list.remove("null")

3.遇到的问题:

  时间过长。

  解决方法:仔细看题发现,原来,本题是已经排好顺序的数组。所以index2没必要把index1后面全部遍历,只需要遍历到第一个和index1的值不同位置即可,后面就全都是不同值。

 class Solution:
def removeDuplicates(self, origin_list):
length = len(origin_list)
#print(origin_list)
for index1 in range(0, length - 1):
for index2 in range(index1 + 1, length):
            #将重复值,标记成null,后面再统一删除
if origin_list[index1] == origin_list[index2]:
origin_list[index2] = 'null'
else:
break
#print(origin_list)
        #将数组中的Null值全部删除
while 'null' in origin_list:
origin_list.remove('null')
new_length = len(origin_list)
return origin_list

总结:

  1.for循环:   

 x = 4
for i in range(0, x):
print(i)
x = 5

  在for循环内部,改变X的值,不能改变迭代次数。

  因为,在执行for循环这行代码中,range()函数的参数X,在循环的第一次循环之前,就已经被python解释器求值(X=4),随后不会的循环中不会再次求值。

  例如:

 x = 4
for j in range(x):
for i in range(x):
print(i)
x = 2
答案:
0
1
2
3
0
1
0
1
0
1

  2.remove()函数,list.remove()会改变列表本身

  3.列表去重:

    3.1set():

      ser(num_list)

    3.2while去重:

      while 重复值 in num_list:

        num_list.remove(重复值)

    

    3.3把列表复制一份,用新列表里面,重复元素的索引index值,删除原列表的值

    

    3.4 倒序去重:

         for i in range(length -1, -1, -1):
if origin_list[i] == 'null':
del origin_list[i]

      

leetcode_day02的更多相关文章

随机推荐

  1. linux客户端传输文件到Windows本地

    1.rz/sz安装及使用方法 和 FileZilla 功能类似用于上传文件,上传速度比较慢适用比较小的文件  yum安装: $ sudo yum install lrzsz   打开SecureCRT ...

  2. 【洛谷P1525】[NOIP2010]关押罪犯

    关押罪犯 题目链接 思路: 二分图或并查集 这里讲并查集算法: 1.将每对罪犯的冲突关系按影响从大到小排序 2.将集合与(i+n)合并表示编号为i的罪犯不能在该集合内 3.依次从大到小处理冲突关系: ...

  3. 由fastRPC产生的DB服务

    根据整理的RPC模型,在此上,根据最近的项目,发布了DB服务,操作数据库.以RPC模型,发布数据库的操作服务,主要发送SQL语句,在服务端执行:同时引入了流行的数据库连接池:服务端还发布了文件接收服务 ...

  4. (一)、Python的简介与安装

    Python简介 Python的创始人为Guido van Rossum.1989年圣诞节期间,在阿姆斯特丹,Guido为了打发圣诞节的无趣,决心开发一个新的脚本解释程序,作为ABC 语言的一种继承. ...

  5. Centos7上docker的安装和基本使用

    Centos7上Docker的相关操作 Docker的安装 1.检查内核版本 docker使用linux的内核必须是3.10以上,首先需要 # uname -r 2.使用yum安装docker # y ...

  6. 无法打开物理文件 XXX.mdf“,操作系统错误 5:”5(拒绝访问。)"的解决办法

    http://blog.csdn.net/blackfield/article/details/6550499 用T-SQL命令附加数据库时,出现如下异常信息: 无法打开物理文件 XXX.mdf&qu ...

  7. Redis 持久化操作

    hash类型 类比:mysql数据库存储数据 持久化操作 以本身的数据以文件形式保存到硬盘中 手动快照持久化 i 备份机制(频率) vi redis.conf save 900 1  900s如果一个 ...

  8. phpstorm 安装XeDbug

    第一步:根据phpinfo()下载相对应的Xdebug插件,Xdebug下载路径https://xdebug.org/download.php 第二步:将下载好的Xdebug放到 G:\Service ...

  9. Python系列6之面向对象

    目录 生成器和迭代器 字符串格式化 内置函数vars 反射 面向对象编程 一. 生成器和迭代器  1. 生成器 生成器具有一种生成的能力,它仅仅代表着一种生成的能力,当我们需要使用的时候,才会通过迭代 ...

  10. 查找并绘制轮廓 opencv

    findContours(): 第二个参数为一个检测到的轮廓,函数调用后的运算结果都放在这里,每个轮廓存储为1个点向量,用point类型的vector表示. 第三个参数表示轮廓数量,包含了许多元素.每 ...