網站首頁 編程語言 正文
一、雙端隊列
雙端隊列 Deque 是一種有次序的數據集,跟隊列相似,其兩端可以稱作"首" 和 "尾"端,但 Deque 中數據項既可以從隊首加入,也可以從隊尾加入;數據項也可以從兩端移除。某種意義上說,雙端隊列集成了棧和隊列的能力。
但雙端隊列并不具有內在的 LIFO 或者 FIFO 特性,如果用雙端隊列來模擬棧或隊列,需要由使用者自行維護操作的一致性。
用 Python 實現抽象數據類型Deque,Deque定義的操作如下:
- Deque():創建一個空雙端隊列;
- add_front(item):將 item 加入隊首;
- add_tail(item):將 item 加入隊尾;
- remove_front():從隊首移除數據項,返回值為移除的數據項;
- remove_tail():從隊尾移除數據項,返回值為移除的數據項;
- is_empty():返回 Deque 是否為空;
- get_size():返回 Deque 中包含數據項的個數。
定義雙端隊列,代碼實現如下:
class Deque: ? ? def __init__(self): ? # 創建空的雙端隊列 ? ? ? ? self.items = [] ? ? def is_empty(self): ? # 判斷雙端隊列是否為空 ? ? ? ? return self.items == [] ? ? def add_front(self, item): ? # 從隊首加入元素? ? ? ? ? self.items.append(item) ? ? def add_tail(self, item): ? ?# 從隊尾加入元素? ? ? ? ? self.items.insert(0, item) ? ? def remove_front(self): ? ? ?# 從隊首刪除元素? ? ? ? ? if self.is_empty(): ? ? ? ? ? ? raise Exception('Queue is empty') ? ? ? ? return self.items.pop() ? ? def remove_tail(self): ? ? ? # 從隊尾刪除元素? ? ? ? ? if self.is_empty(): ? ? ? ? ? ? raise Exception('Queue is empty') ? ? ? ? return self.items.pop(0) ? ? def get_size(self): ? ? ? ? ?# 獲取雙端隊列元素數量 ? ? ? ? return len(self.items)
操作復雜度:add_front / remove_front,O(1);add_tail / remove_tail,O(n)。
二、回文檢測
“回文詞” 指正讀和反讀都一樣的詞,如radar、bob、toot;中文:“上海自來水來自海上”,“山東落花生花落東山”。
用雙端隊列很容易解決 “回文詞” 問題,先將需要判定的詞從隊尾加入Deque,再從兩端同時移除字符判定是否相同,直到 Deque 中剩下 0 個或 1 個字符。
算法實現如下:
def palindrome_check(string): ? # 回文檢測 ? ? str_deque = Deque() ? ? for item in string: ? ? ? ? str_deque.add_front(item) ? ? ? ?? ? ? check_flag = True ? ? while str_deque.get_size() > 1 and check_flag: ? ? ? ? left = str_deque.remove_front() ? # 隊尾移除 ? ? ? ? right = str_deque.remove_tail() ? # 隊首移除 ? ? ? ? if left != right: ? # 只要有一次不相等 ? 不是回文 ? ? ? ? ? ? check_flag = False ? ? # 判斷完一遍 ? check_flag為True ?是回文 ? ? return check_flag print(palindrome_check("radar")) print(palindrome_check("abcbac")) print(palindrome_check("上海自來水來自海上"))
補充
Python還可以通過雙游標判斷字符串是否是回文串
從字符串s兩端指定兩個游標low,high
如果low游標指向了 非字母和數字(即空格和符號),那么low游標往后移一位;
如果high游標指向了 非字母和數字(即空格和符號),那么high游標往前移一位;
直至low和high都指向了數字或字母,此時進行比較,是否相同。
如果比較的結果是True,則low往后移一位,high往前移一位
如果比較的結果是False,則直接返回False
重復上述判斷,直至low和high重合,此時表示完成了字符串s內前后元素的一一對比判斷,返回True即可。
代碼如下
class Solution(object): def isPalindrome(self, s): """ :type s: str :rtype: bool """ low = 0 high = len(s) - 1 #在字符串為空或只有一個字符時,返回True if len(s) <= 1: return True # 設定low和high對比的條件 while low < high: # 如果不是字母或數字,low往后移一位【low < high為必須條件,不然會造成索引越界】 while not s[low].isalnum() and low < high: low += 1 # 如果不是字母或數字,high往前移一位 while not s[high].isalnum() and low < high: high -= 1 # 判斷:如果相同,繼續下一次對比;如果不相同,直接返回False if s[low].lower() == s[high].lower(): low += 1 high -= 1 else: return False # low和high重合,即退出循環,表示前后都是一一對應的,返回True return True
原文鏈接:https://blog.csdn.net/fyfugoyfa/article/details/113864287
相關推薦
- 2023-03-29 基于WPF實現多選下拉控件的示例代碼_C#教程
- 2022-04-18 Go中groutine通信與context控制實例詳解_Golang
- 2024-02-26 IDEA設置字體大小
- 2022-07-06 Flutter?DateTime日期轉換的詳細使用_Android
- 2023-04-07 C#?PadLeft、PadRight用法詳解_C#教程
- 2022-11-04 C++淺析內存分區模型概念與示例_C 語言
- 2022-10-20 Flutter投票組件使用方法詳解_Android
- 2022-09-06 React封裝CustomSelect組件思路詳解_React
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支