python代码实现将列表中重复元素之间的内容全部滤除


Posted in Python onMay 22, 2020

1. 引言

因为在学习遗传算法路径规划的内容,其中遗传算法中涉及到了种群的初始化,而在路径规划的种群初始化中,种群初始化就是先找到一条条从起点到终点的路径,也因此需要将路径中重复节点之间的路径删除掉(避免走回头路),这样子初始种群会比较优越,也能加快算法收敛速度。然后我在搜资料的时候发现,许多的代码都是滤除列表中相同元素的,并没有滤除相同元素中间段的代码,因此就自己写了。

2. 代码部分

我在python程序中把每一条路径用列表表示的,因此每一个列表就是一条路径比如
a = [0,1,3,4,5,6,3,4,7,3,5,8,9,8,10,13,11,12,10]
a就是一条路径起点为0,终点为10,但是可以看到,中间有许多回头路。因此设计算法将冗余部分滤除。代码如下,带有详细注释:

a = [0,1,3,4,5,6,3,4,7,3,5,8,9,8,10,13,11,12,10]#初始列表

def fiter(a):    #定义一个函数
  for i in a:   #遍历列表中的内容
    a = a[a.index(i)+1:]  #把当前内容索引的后面的内容剪切下来 因为前面的已经比对过了
    if i in a:   #如果当前内容与后面有重复
      return i,1  #返回当前重复的内容 以及标志位1
    else:      #没有重复就不用管 继续for循环
      pass 
  return 0,0 #全部遍历完 没有重复的就返回0 这里返回两个0 是因为返回的数量要保持一致
b = 1  #标志位 
while(b == 1): #标志位一直是 1 则说明有重复的内容
  (i,b) = fiter(a)    #此时接受函数接收 返回值 i是重复的内容 b是标志位
  c = [j for j,x in enumerate(a) if x==i] #将重复内容的索引全部添加进c列表中
  a = a[0:c[0]]+a[c[-1]:]   #a列表切片在重组
print(a)

3. 结果

python代码实现将列表中重复元素之间的内容全部滤除

这段代码还有改进的地方,可以把整体代码封装成函数,留着慢慢品吧

4. 续

算了,放在遗传算法总工程中,发现还是要封装起来,直接贴代码吧
代码如下:

a = [0,1,3,4,5,6,3,4,7,3,5,8,9,8,10,13,11,12,10]
class Fiter:
  def __init__(self):
    self.b = 1  #标志位
  def function(self,a):    #定义一个函数
    for i in a:   #遍历列表中的内容
      a = a[a.index(i)+1:]  #把当前内容索引的后面的内容剪切下来 因为前面的已经比对过了
      if i in a:   #如果当前内容与后面有重复
        return i,1  #返回当前重复的内容 以及标志位1
      else:      #没有重复就不用管 继续for循环
        pass 
    return 0,0 #全部遍历完 没有重复的就返回0 这里返回两个0 是因为返回的数量要保持一致
  
  def fiter(self,a):
    while(self.b == 1): #标志位一直是 1 则说明有重复的内容
      (i,self.b) = self.function(a)    #此时接受函数接收 返回值 i是重复的内容 b是标志位
      c = [j for j,x in enumerate(a) if x==i] #将重复内容的索引全部添加进c列表中
      a = a[0:c[0]]+a[c[-1]:]   #a列表切片在重组
    return (a)
fiter = Fiter() #实例化
a = fiter.fiter(a) #调用方法 返回已经滤除的列表
print(a)

这里直接封装成了类对象,使用得时候先实例化再调用方法就行了。结果和上面的结果是一样的。

总结

到此这篇关于python代码实现将列表中重复元素之间的内容全部滤除的文章就介绍到这了,更多相关python列表重复元素滤除内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python中os.path用法分析
Jan 15 Python
详解python的几种标准输出重定向方式
Aug 15 Python
Python实现识别手写数字大纲
Jan 29 Python
python dataframe astype 字段类型转换方法
Apr 11 Python
Python将一个Excel拆分为多个Excel
Nov 07 Python
django之状态保持-使用redis存储session的例子
Jul 28 Python
通过实例了解python property属性
Nov 01 Python
Python和Anaconda和Pycharm安装教程图文详解
Feb 04 Python
Python flask框架实现浏览器点击自定义跳转页面
Jun 04 Python
详解Python牛顿插值法
May 11 Python
Python3 多线程(连接池)操作MySQL插入数据
Jun 09 Python
Python编写nmap扫描工具
Jul 21 Python
Tensorflow实现将标签变为one-hot形式
May 22 #Python
Python selenium爬取微博数据代码实例
May 22 #Python
python实现文法左递归的消除方法
May 22 #Python
使用Django搭建网站实现商品分页功能
May 22 #Python
Tensorflow卷积实现原理+手写python代码实现卷积教程
May 22 #Python
Python实现发票自动校核微信机器人的方法
May 22 #Python
基于django micro搭建网站实现加水印功能
May 22 #Python
You might like
安装PHP可能遇到的问题“无法载入mysql扩展” 的解决方法
2007/04/16 PHP
MYSQL 小技巧 -- LAST_INSERT_ID
2009/11/24 PHP
PHP面向对象编程之深入理解方法重载与方法覆盖(多态)
2015/12/24 PHP
PHP基于curl后台远程登录正方教务系统的方法
2016/10/14 PHP
PHP仿qq空间或朋友圈发布动态、评论动态、回复评论、删除动态或评论的功能(上)
2017/05/26 PHP
PHP实现登陆并抓取微信列表中最新一组微信消息的方法
2017/07/10 PHP
php模拟实现斗地主发牌
2020/04/22 PHP
基于JQuery的多标签实现代码
2012/09/19 Javascript
JavaScript使用循环和分割来替换和删除元素实例
2014/10/13 Javascript
解决JavaScript数字精度丢失问题的方法
2015/12/03 Javascript
JavaScript通过代码调用Flash显示的方法
2016/02/02 Javascript
javascript 分号总结及详细介绍
2016/09/24 Javascript
JavaScript 继承详解(六)
2016/10/11 Javascript
微信 java 实现js-sdk 图片上传下载完整流程
2016/10/21 Javascript
Vue兼容ie9的问题全面解决方案
2018/06/19 Javascript
VUE-cli3使用 svg-sprite-loader
2018/10/20 Javascript
了解javascript中let和var及const关键字的区别
2019/05/24 Javascript
使用JS判断页面是首次被加载还是刷新
2019/05/26 Javascript
微信小程序实现原生步骤条
2019/07/25 Javascript
前端开发之便利店收银系统代码
2019/12/27 Javascript
vue自定义指令限制输入框输入值的步骤与完整代码
2020/08/30 Javascript
Python 连连看连接算法
2008/11/22 Python
Python求解任意闭区间的所有素数
2018/06/10 Python
PyQt5实现暗黑风格的计时器
2019/07/29 Python
python小项目之五子棋游戏
2019/12/26 Python
python Tensor和Array对比分析
2020/01/08 Python
Python-openCV读RGB通道图实例
2020/01/17 Python
pycharm激活方法到2099年(激活流程)
2020/09/22 Python
Django restful framework生成API文档过程详解
2020/11/12 Python
TensorFlow2.0使用keras训练模型的实现
2021/02/20 Python
购买中国最好的电子产品:Geekbuying
2018/03/13 全球购物
MediaMarkt比利时:欧洲最大电器连锁店
2020/12/21 全球购物
妇女工作先进事迹
2014/08/17 职场文书
毕业实习指导教师评语
2014/12/31 职场文书
员工旷工检讨书
2015/08/15 职场文书
CSS浮动引起的高度塌陷问题
2022/08/05 HTML / CSS