檢查 Python 中陣列是否可以透過一次交換排序
假設,我們得到一個包含整數元素的陣列。我們必須找出如果我們只能執行一次交換操作,陣列中的值是否可以按非遞減順序排序。如果可能,我們說可以完成,否則不可以。
因此,如果輸入類似於 input_list = [7, 8, 12, 10, 11, 9],則輸出將為“可以完成”
為了解決這個問題,我們將遵循以下步驟 -
- temp_list := 列表 input_list 的副本
- 對列表 temp_list 進行排序
- swap_count := 0
- 對於 i 的範圍從 0 到 input_list 的大小,執行
- 如果 input_list[i] 與 temp_list[i] 不相同,則
- swap_count := swap_count + 1
- 如果 input_list[i] 與 temp_list[i] 不相同,則
- 如果 swap_count 與 0 相同或 swap_count 與 2 相同,則
- 返回 True
- 否則,
- 返回 False
讓我們看看以下實現以獲得更好的理解 -
示例
from copy import deepcopy
def solve(input_list):
temp_list = deepcopy(input_list)
temp_list.sort()
swap_count = 0
for i in range(len(input_list)):
if input_list[i] != temp_list[i]:
swap_count += 1
if swap_count == 0 or swap_count == 2:
print("Can be done")
else:
print("Can't be done")
input_list = [7, 8, 12, 10, 11, 9]
solve(input_list)輸入
[7, 8, 12, 10, 11, 9]
輸出
Can be done
廣告
資料結構
網路
關係資料庫管理系統
作業系統
Java
iOS
HTML
CSS
Android
Python
C 程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP