全网求解,用Python处理一个基础题目

昨天在群里看见一个Python的问题,趁着今天有那么一点点时间,就想把这个题目分享出来,让大家一起解决。毕竟三个臭皮匠,赛过诸葛

亮。
在这里插入图片描述

原始数据如下:

1

origin_lst = [0, 0, 1, 2, 3, 4, 4, 5, 6, 6, 6, 7, 8, 9, 4, 4]




期望得到的结果是:



1

[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 4]

在这里插入图片描述

实现过程

方法一

这里【老松鼠】给了一份代码,如下所示:

Python学习交流Q群:906715085####
import itertools
origin_lst = [0, 0, 1, 2, 3, 4, 4, 5, 6, 6, 6, 7, 8, 9, 4, 4]

final_lst = [x[0] for x in itertools.groupby(origin_lst)]
# final_lst = [k for k, g in itertools.groupby(origin_lst)]
print(final_lst)

在这里插入图片描述

运行之后,得到的结果可以满足预期,如下图所示:

在这里插入图片描述

方法二

后来【瑜亮老师】也给了一份代码,使用列表推导式,如下所示:

origin_lst = [0, 0, 1, 2, 3, 4, 4, 5, 6, 6, 6, 7, 8, 9, 4, 4]

res = [origin_lst[i] for i in range(len(origin_lst)) if i == 0 or origin_lst[i] != origin_lst[i - 1]]
print(res)

运行结果如下图所示:

在这里插入图片描述

顺利的解决了问题。

在这里插入图片描述

方法三

后来给了一个基础的方法,如下所示:

origin_lst = [0, 0, 1, 2, 3, 4, 4, 5, 6, 6, 6, 7, 8, 9, 4, 4]

result = [origin_lst[0]]
for i in range(1, len(origin_lst)):    
if origin_lst[i] != origin_lst[i-1]:        
result.append(origin_lst[i])
print(result)

运行结果如下图所示:

在这里插入图片描述

方法四

后来还给了一个生成器的方法,如下所示:

Python学习交流Q群:906715085####
origin_lst = [0, 0, 1, 2, 3, 4, 4, 5, 6, 6, 6, 7, 8, 9, 4, 4]

def del_adjacent(iterable):    
prev = object()   
 for item in iterable:        
 if item != prev:            
 prev = item            
 yield item

result = list(del_adjacent(origin_lst))
print(result)

在这里插入图片描述

运行结果如下所示:

在这里插入图片描述

方法五

后来【Chloe】自己也给了一个enumerate方法,代码如下所示:

origin_lst = [0, 0, 1, 2, 3, 4, 4, 5, 6, 6, 6, 7, 8, 9, 4, 4]
lst_final = []
for index, val in enumerate(origin_lst):    
if val != origin_lst[index - 1]:        
lst_final.append(val)
print(lst_final)

运行结果如下图所示:

在这里插入图片描述

最后

事实证明,条条大路通罗马,方法还是很多的!以后大家在遇到问题的时候也可以试着去打开自己的思维,或许可以得到更多的解决方法。

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/xff123456_/article/details/125204687