欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python亂序字符串排序的實(shí)現(xiàn)方式

 更新時(shí)間:2022年11月01日 17:01:47   作者:夢(mèng)入玄機(jī)  
這篇文章主要介紹了python亂序字符串排序的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

python亂序字符串排序

什么是亂序字符串排序

亂序字符串排序是指一個(gè)字符串是另一個(gè)字符串的亂序排序,比如apple就是eppal的亂序字符串。

檢查

假設(shè)字符串由26個(gè)小寫字符串組成。

1、時(shí)間復(fù)雜度O(n^2)

解決方案:

判斷兩個(gè)字符串長(zhǎng)度是否相等,若不相等返回False,不相等則判斷第一個(gè)字符串的字符是否在第二個(gè)字符串中,如果不在,返回False,如果在則把第二個(gè)字符串中查找的位置元素置為None,因?yàn)橐淖兊诙€(gè)字符串,需把第二個(gè)字符串轉(zhuǎn)換為list,代碼如下:

def none_sort_str(s1, s2):
? ? s2_list = list(s2)
? ? if len(s1) != len(s2):
? ? ? ? return False
? ? else:
? ? ? ? for i in range(len(s1)):
? ? ? ? ? ? for j in range(len(s2_list)):
? ? ? ? ? ? ? ? if s1[i] in s2_list:
? ? ? ? ? ? ? ? ? ? s2_list[s2_list.index(s1[i])] = None
? ? ? ? ? ? ? ? ? ? break
? ? ? ? ? ? ? ? else:
? ? ? ? ? ? ? ? ? ? return False
? ? return True

2、時(shí)間復(fù)雜度O(n)

解決方案:

判斷兩個(gè)字符串長(zhǎng)度是否相等,若不相等返回False,使用計(jì)數(shù)方式,代碼如下:

def none_sort_str2(s1, s2):
? ? a = [0] * 26
? ? b = [0] * 26
? ? for i in range(len(s1)):
? ? ? ? index1 = ord(s1[i]) - ord('a')
? ? ? ? a[index1] += 1
? ? for i in range(len(s2)):
? ? ? ? index2 = ord(s2[i]) - ord('a')
? ? ? ? b[index2] += 1
? ? if a == b:
? ? ? ? return True
? ? else:
? ? ? ? return False

亂序字符串檢查算法研究 

顯示不同量級(jí)的算法的一個(gè)很好的例子是字符串的亂序檢查。亂序字符串是指一個(gè)字符串只是另一個(gè)字符串的重新排列。

例如,'heart' 和 'earth' 就是亂序字符串。'python' 和 'typhon' 也是。為了簡(jiǎn)單起見,我們假設(shè)所討論的兩個(gè)字符串具有相等的長(zhǎng)度,并且他們由 26 個(gè)小寫字母集合組成。我們的目標(biāo)是寫一個(gè)布爾函數(shù),它將兩個(gè)字符串做參數(shù)并返回它們是不是亂序。

解法一

思路:將兩個(gè)字符串都轉(zhuǎn)化成列表,然后遍歷其中一個(gè),當(dāng)前元素在另外一個(gè)列表中就把另一個(gè)列表的對(duì)應(yīng)元素移除(防止重復(fù)干擾)。不存在就返回FALSE,遍歷完成返回True

代碼參考如下:

str1 = 'hagjen'
str2 = 'ahejng'
def foo(str1,str2):
? ? ls1 = list(str1)
? ? ls2 = list(str2)
? ? for i in ls1:
? ? ? ? if i in ls2:
? ? ? ? ? ? ls2.remove(i)
? ? ? ? else:return False
? ? return True
print(foo(str1,str2))

算法復(fù)雜度:兩層for循環(huán),都是和n線性相關(guān),所以這個(gè)算法復(fù)雜度為 O(n^2 )。

解法二

兩個(gè)字符串也都轉(zhuǎn)為列表,然后排序當(dāng)排序后連個(gè)列表相等就返回True,否則FALSE

str1 = 'hagjen'
str2 = 'ahejng'
def foo(str1,str2):
? ? ls1 = list(str1).sort()
? ? ls2 = list(str2) .sort()
? ? return True if ls1==ls2 else False
print(foo(str1,str2))

算法復(fù)雜度:咋一看完全沒有循環(huán),復(fù)雜度好像非常低,但是別忘了排序!排序是python內(nèi)部實(shí)現(xiàn)的,它也需要時(shí)間消耗,排序的算法復(fù)雜度一般是O(nlog(n)),O(n^2)。所以這種方法不一定比上面的好

解法三

建立兩個(gè)長(zhǎng)度為26的列表,分別遍歷兩個(gè)字符串,分別計(jì)數(shù),最后兩個(gè)列表相同就返回True

def foo(s1,s2):
? ? ls1 = list(s1)
? ? ls2 = list(s2)
? ? count1 = [0 for ?i in range(26)]
? ? count2 = [0 for ?i in range(26)]
? ? print(count1)
? ? print(count2)
? ? for ?i in ls1:
? ? ? ? count1[ord(i)-ord('a')] +=1
? ? for ?i in ls2:
? ? ? ? count2[ord(i)-ord('a')] +=1
? ? return True if count1==count2 else False
print(foo('aacf','cfaa'))

時(shí)間復(fù)雜度:由于沒有循環(huán)嵌套也沒有排序等算法,時(shí)間復(fù)雜度為2n+26,即O(n)

代碼優(yōu)化:

def is_simlar(s1, s2):
? ? from collections import Counter
? ? return Counter(s1) == Counter(s2)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。  

相關(guān)文章

  • Python?NumPy科學(xué)計(jì)算庫的高級(jí)應(yīng)用

    Python?NumPy科學(xué)計(jì)算庫的高級(jí)應(yīng)用

    這篇文章主要為大家介紹了Python?NumPy科學(xué)計(jì)算庫的高級(jí)應(yīng)用深入詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • 盤點(diǎn)Python?爬蟲中的常見加密算法

    盤點(diǎn)Python?爬蟲中的常見加密算法

    這篇文章主要介紹了盤點(diǎn)Python?爬蟲中的常見加密算法,加密即Encryption指將明文數(shù)據(jù)變換為密文的過程,解密即Decryption指加密的逆過程,即由密文恢復(fù)出原明文的過程
    2022-07-07
  • Python實(shí)用技巧之輕松處理大型文件

    Python實(shí)用技巧之輕松處理大型文件

    Python在文件處理方面提供了非常強(qiáng)大的支持,然而,當(dāng)處理大型文件時(shí),標(biāo)準(zhǔn)的文件處理技術(shù)會(huì)導(dǎo)致高內(nèi)存使用,所以下面我們就來看看如何在Python中有效地處理大型文件吧
    2024-03-03
  • 如何基于Python + requests實(shí)現(xiàn)發(fā)送HTTP請(qǐng)求

    如何基于Python + requests實(shí)現(xiàn)發(fā)送HTTP請(qǐng)求

    這篇文章主要介紹了如何基于Python + requests實(shí)現(xiàn)發(fā)送HTTP請(qǐng)求,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-01-01
  • 詳解Python異常處理中的Finally else的功能

    詳解Python異常處理中的Finally else的功能

    本篇文章主要介紹了詳解Python異常處理中的Finally else的功能,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-12-12
  • python如何把字符串類型list轉(zhuǎn)換成list

    python如何把字符串類型list轉(zhuǎn)換成list

    這篇文章主要介紹了python如何吧字符串類型list轉(zhuǎn)換成list,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-02-02
  • python?matplotlib畫圖時(shí)坐標(biāo)軸重疊顯示不全和圖片保存時(shí)不完整的問題解決

    python?matplotlib畫圖時(shí)坐標(biāo)軸重疊顯示不全和圖片保存時(shí)不完整的問題解決

    最近工作中遇到了matplotlib保存圖片坐標(biāo)軸不完整的問題,所以這篇文章主要給大家介紹了關(guān)于python?matplotlib畫圖時(shí)坐標(biāo)軸重疊顯示不全和圖片保存時(shí)不完整問題的解決方法,需要的朋友可以參考下
    2022-07-07
  • 教你如何識(shí)別代理IP的真實(shí)地理位置(使用Python庫)

    教你如何識(shí)別代理IP的真實(shí)地理位置(使用Python庫)

    本文介紹了IP數(shù)據(jù)庫查詢、反向DNS查詢和網(wǎng)絡(luò)延遲測(cè)量三種方法,并通過案例分析和代碼實(shí)現(xiàn)展示了如何使用Python庫進(jìn)行IP地理位置查詢,需要的朋友可以參考下
    2024-03-03
  • 使用python加密自己的密碼

    使用python加密自己的密碼

    本文給大家分享的是使用python加密自己的密碼的思路和代碼,非常的簡(jiǎn)單實(shí)用,有需要的小伙伴可以參考下。
    2015-08-08
  • Python日期和時(shí)間戳的轉(zhuǎn)換的實(shí)現(xiàn)方式

    Python日期和時(shí)間戳的轉(zhuǎn)換的實(shí)現(xiàn)方式

    Python中日期和時(shí)間的處理涉及到time和datetime模塊,time模塊可實(shí)現(xiàn)時(shí)間戳與格式化時(shí)間字符串的轉(zhuǎn)換,而datetime模塊則提供更加直接易用的接口,本文詳細(xì)給大家介紹了Python日期和時(shí)間戳的轉(zhuǎn)換的實(shí)現(xiàn)方式,需要的朋友可以參考下
    2024-10-10

最新評(píng)論