Python 中查詢透過一次交換得到的最小的字典序字串的程式
假設我們有一個字串 s,我們需要找到透過最多交換兩個字元可以得到的字典序最小的字串。
因此,如果輸入為 "zyzx",則輸出將為 "xyzz"
為了解決這個問題,我們將遵循以下步驟:
- temp := 一個大小為 s 的陣列,並用 0 填充
- m:= s 的大小 - 1
- 對於 i 在 s 的大小 -1 到 -1 的範圍內,遞減 1,執行以下操作:
- 如果 s[i] < s[m],則
- m := i
- temp[i] := m
- 對於 i 在 0 到 s 的大小的範圍內,執行以下操作:
- a := temp[i]
- 如果 s[a] 與 s[i] 不相同,則
- 返回 s 的子字串(從索引 0 到 i)連線 s[a] 連線 s 的子字串(從索引 i+1 到 a)連線 s[i] 連線 s 的子字串(從索引 a+1 到結尾)
- 如果 s[i] < s[m],則
- 返回 s
示例
class Solution:
def solve(self, s):
temp = [0]*len(s)
m=len(s)-1
for i in range(len(s)-1, -1, -1):
if s[i]<s[m]: m=i
temp[i] = m
for i in range(len(s)):
a = temp[i]
if s[a] != s[i]:
return s[:i]+s[a]+s[i+1:a]+s[i]+s[a+1:]
return s
ob = Solution()
print(ob.solve("zyzx"))輸入
zyzx
輸出
xyzz
廣告
資料結構
網路
關係資料庫管理系統
作業系統
Java
iOS
HTML
CSS
Android
Python
C 語言程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP