產生數組的所有排列
給定一個由不同元素組成的數組,目標是列出數組元素的所有可能排列。
演算法
以下演算法在O(N!) 時間內產生所有排列複雜度:
- 初始化: 設定🎜>
- 初始化: 設定🎜> 初始化:
- 設定🎜>初始化: 設定🎜>
- 初始化: 設定🎜>
- 初始化: 設定🎜> 初始化:
- 設定🎜>初始化: 設定🎜>
初始化:
設= 0。def permute(arr, i=0): if i == len(arr) - 1: print(arr) return for j in range(i, len(arr)): arr[i], arr[j] = arr[j], arr[i] permute(arr, i + 1) arr[i], arr[j] = arr[j], arr[i]迭代數組:
當i 小於數組長度時:
- 交換: 將索引i 處的元素與每個交換數組中剩餘元素的值。
- 遞歸: 遞歸呼叫演算法,以 i 1 為新的 i 值。
- 交換回來:遞歸呼叫後,將元素交換回原來的狀態
- 增加 i: 將 i 加 1。
- Python 實作 Jarvis March 演算法
- 對於具有重複元素的數組,Jarvis March 演算法 對於具有重複元素的數組,Jarvis March 演算法是一種更有效率的演算法方法:
- 排序:
def permute_repeated(arr): ind = [0] * len(arr) for i in range(len(arr)): ind[i] = i while True: yield [arr[i] for i in ind] for i in range(len(arr) - 2, -1, -1): if ind[i] arr[i]: ind[i], ind[j] = ind[j], ind[i] break ind[i + 1:] = sorted(ind[i + 1:])當: 未完成時: 找出主元:找出元素小於其的最大索引後繼者。 找出相鄰: 找出排序部分中大於樞軸索引處的元素的最後一個元素。 交換:交換樞軸和相鄰索引處的元素。 反轉:反轉從樞軸索引到排序部分末端的元素。 檢查完成:檢查陣列是否依降序排序。如果是,則退出循環。 Python 實作
以上是如何產生數組的所有排列,包括具有重複元素的排列?的詳細內容。更多資訊請關注PHP中文網其他相關文章!
陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前By尊渡假赌尊渡假赌尊渡假赌
刺客信條陰影:貝殼謎語解決方案
3 週前ByDDD
Windows 11 KB5054979中的新功能以及如何解決更新問題
2 週前ByDDD
威爾R.E.P.O.有交叉遊戲嗎?
1 個月前By尊渡假赌尊渡假赌尊渡假赌

熱工具

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

Dreamweaver CS6
視覺化網頁開發工具

WebStorm Mac版
好用的JavaScript開發工具

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

記事本++7.3.1
好用且免費的程式碼編輯器