亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

python代碼實(shí)現(xiàn)將列表中重復(fù)元素之間的內(nèi)容全部濾除

 更新時(shí)間:2020年05月22日 11:03:48   作者:知識(shí),請(qǐng)你尊重我  
這篇文章主要介紹了python代碼實(shí)現(xiàn)將列表中重復(fù)元素之間的內(nèi)容全部濾除,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

1. 引言

因?yàn)樵趯W(xué)習(xí)遺傳算法路徑規(guī)劃的內(nèi)容,其中遺傳算法中涉及到了種群的初始化,而在路徑規(guī)劃的種群初始化中,種群初始化就是先找到一條條從起點(diǎn)到終點(diǎn)的路徑,也因此需要將路徑中重復(fù)節(jié)點(diǎn)之間的路徑刪除掉(避免走回頭路),這樣子初始種群會(huì)比較優(yōu)越,也能加快算法收斂速度。然后我在搜資料的時(shí)候發(fā)現(xiàn),許多的代碼都是濾除列表中相同元素的,并沒有濾除相同元素中間段的代碼,因此就自己寫了。

2. 代碼部分

我在python程序中把每一條路徑用列表表示的,因此每一個(gè)列表就是一條路徑比如
a = [0,1,3,4,5,6,3,4,7,3,5,8,9,8,10,13,11,12,10]
a就是一條路徑起點(diǎn)為0,終點(diǎn)為10,但是可以看到,中間有許多回頭路。因此設(shè)計(jì)算法將冗余部分濾除。代碼如下,帶有詳細(xì)注釋:

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

def fiter(a):    #定義一個(gè)函數(shù)
  for i in a:   #遍歷列表中的內(nèi)容
    a = a[a.index(i)+1:]  #把當(dāng)前內(nèi)容索引的后面的內(nèi)容剪切下來 因?yàn)榍懊娴囊呀?jīng)比對(duì)過了
    if i in a:   #如果當(dāng)前內(nèi)容與后面有重復(fù)
      return i,1  #返回當(dāng)前重復(fù)的內(nèi)容 以及標(biāo)志位1
    else:      #沒有重復(fù)就不用管 繼續(xù)for循環(huán)
      pass 
  return 0,0 #全部遍歷完 沒有重復(fù)的就返回0 這里返回兩個(gè)0 是因?yàn)榉祷氐臄?shù)量要保持一致
b = 1  #標(biāo)志位 
while(b == 1): #標(biāo)志位一直是 1 則說明有重復(fù)的內(nèi)容
  (i,b) = fiter(a)    #此時(shí)接受函數(shù)接收 返回值 i是重復(fù)的內(nèi)容 b是標(biāo)志位
  c = [j for j,x in enumerate(a) if x==i] #將重復(fù)內(nèi)容的索引全部添加進(jìn)c列表中
  a = a[0:c[0]]+a[c[-1]:]   #a列表切片在重組
print(a)

3. 結(jié)果

上述代碼運(yùn)行結(jié)果

這段代碼還有改進(jìn)的地方,可以把整體代碼封裝成函數(shù),留著慢慢品吧

4. 續(xù)

算了,放在遺傳算法總工程中,發(fā)現(xiàn)還是要封裝起來,直接貼代碼吧
代碼如下:

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  #標(biāo)志位
  def function(self,a):    #定義一個(gè)函數(shù)
    for i in a:   #遍歷列表中的內(nèi)容
      a = a[a.index(i)+1:]  #把當(dāng)前內(nèi)容索引的后面的內(nèi)容剪切下來 因?yàn)榍懊娴囊呀?jīng)比對(duì)過了
      if i in a:   #如果當(dāng)前內(nèi)容與后面有重復(fù)
        return i,1  #返回當(dāng)前重復(fù)的內(nèi)容 以及標(biāo)志位1
      else:      #沒有重復(fù)就不用管 繼續(xù)for循環(huán)
        pass 
    return 0,0 #全部遍歷完 沒有重復(fù)的就返回0 這里返回兩個(gè)0 是因?yàn)榉祷氐臄?shù)量要保持一致
  
  def fiter(self,a):
    while(self.b == 1): #標(biāo)志位一直是 1 則說明有重復(fù)的內(nèi)容
      (i,self.b) = self.function(a)    #此時(shí)接受函數(shù)接收 返回值 i是重復(fù)的內(nèi)容 b是標(biāo)志位
      c = [j for j,x in enumerate(a) if x==i] #將重復(fù)內(nèi)容的索引全部添加進(jìn)c列表中
      a = a[0:c[0]]+a[c[-1]:]   #a列表切片在重組
    return (a)
fiter = Fiter() #實(shí)例化
a = fiter.fiter(a) #調(diào)用方法 返回已經(jīng)濾除的列表
print(a)

這里直接封裝成了類對(duì)象,使用得時(shí)候先實(shí)例化再調(diào)用方法就行了。結(jié)果和上面的結(jié)果是一樣的。

總結(jié)

到此這篇關(guān)于python代碼實(shí)現(xiàn)將列表中重復(fù)元素之間的內(nèi)容全部濾除的文章就介紹到這了,更多相關(guān)python列表重復(fù)元素濾除內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • python爬蟲中抓取指數(shù)的實(shí)例講解

    python爬蟲中抓取指數(shù)的實(shí)例講解

    在本篇文章里小編給大家整理了關(guān)于python爬蟲中抓取指數(shù)的實(shí)例講解內(nèi)容,有興趣的朋友們學(xué)習(xí)下。
    2020-12-12
  • Python排序算法之冒泡排序

    Python排序算法之冒泡排序

    我們?cè)诰帉懘a時(shí),經(jīng)常需要對(duì)一些序列做一些排序,排序的方法很多,下面我們講一下常用的冒泡排序法。需要的朋友可以參考下
    2023-01-01
  • 詳解python的xlwings庫讀寫excel操作總結(jié)

    詳解python的xlwings庫讀寫excel操作總結(jié)

    這篇文章主要介紹了詳解python的xlwings庫讀寫excel操作總結(jié),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • Tensorflow簡(jiǎn)單驗(yàn)證碼識(shí)別應(yīng)用

    Tensorflow簡(jiǎn)單驗(yàn)證碼識(shí)別應(yīng)用

    這篇文章主要為大家詳細(xì)介紹了Tensorflow簡(jiǎn)單驗(yàn)證碼識(shí)別應(yīng)用的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • Python實(shí)現(xiàn)隊(duì)列的方法

    Python實(shí)現(xiàn)隊(duì)列的方法

    這篇文章主要介紹了Python實(shí)現(xiàn)隊(duì)列的方法,實(shí)例分析了Python實(shí)現(xiàn)隊(duì)列的相關(guān)技巧,需要的朋友可以參考下
    2015-05-05
  • 利用python畫出AUC曲線的實(shí)例

    利用python畫出AUC曲線的實(shí)例

    今天小編就為大家分享一篇利用python畫出AUC曲線的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-02-02
  • 學(xué)python爬蟲能做什么

    學(xué)python爬蟲能做什么

    這篇文章主要介紹了學(xué)python爬蟲能做什么的相關(guān)知識(shí)點(diǎn)內(nèi)容,有需要的朋友們可以閱讀參考下。
    2020-07-07
  • python單例設(shè)計(jì)模式實(shí)現(xiàn)解析

    python單例設(shè)計(jì)模式實(shí)現(xiàn)解析

    這篇文章主要介紹了python單例設(shè)計(jì)模式實(shí)現(xiàn)解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-01-01
  • python tkinter之頂層菜單、彈出菜單實(shí)例

    python tkinter之頂層菜單、彈出菜單實(shí)例

    這篇文章主要介紹了python tkinter之頂層菜單、彈出菜單實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-03-03
  • pytest內(nèi)置fixture使用臨時(shí)目錄流程詳解

    pytest內(nèi)置fixture使用臨時(shí)目錄流程詳解

    fixture是在測(cè)試函數(shù)運(yùn)行前后,由pytest執(zhí)行的外殼函數(shù)。fixture中的代碼可以定制,滿足多變的測(cè)試需求,包括定義傳入測(cè)試中的數(shù)據(jù)集、配置測(cè)試前系統(tǒng)的初始狀態(tài)、為批量測(cè)試提供數(shù)據(jù)源等等。fixture是pytest的精髓所在
    2022-12-12

最新評(píng)論