Python双端队列 实现回文检测

简介: 双端队列 Deque 是一种有次序的数据集,跟队列相似,其两端可以称作"首" 和 "尾"端,但 Deque 中数据项既可以从队首加入,也可以从队尾加入;数据项也可以从两端移除。某种意义上说,双端队列集成了栈和队列的能力。

一、双端队列


双端队列 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 中包含数据项的个数。


定义双端队列,代码实现如下:


classDeque:
def__init__(self):   # 创建空的双端队列self.items= []
defis_empty(self):   # 判断双端队列是否为空returnself.items== []
defadd_front(self, item):   # 从队首加入元素 self.items.append(item)
defadd_tail(self, item):    # 从队尾加入元素 self.items.insert(0, item)
defremove_front(self):      # 从队首删除元素 ifself.is_empty():
raiseException('Queue is empty')
returnself.items.pop()
defremove_tail(self):       # 从队尾删除元素 ifself.is_empty():
raiseException('Queue is empty')
returnself.items.pop(0)
defget_size(self):          # 获取双端队列元素数量returnlen(self.items)


操作复杂度:add_front / remove_front,O(1);add_tail / remove_tail,O(n)。


二、回文检测


“回文词” 指正读和反读都一样的词,如radar、bob、toot;中文:“上海自来水来自海上”,“山东落花生花落东山”。


用双端队列很容易解决 “回文词” 问题,先将需要判定的词从队尾加入Deque,再从两端同时移除字符判定是否相同,直到 Deque 中剩下 0 个或 1 个字符。


算法实现如下:


defpalindrome_check(string):   # 回文检测str_deque=Deque()
foriteminstring:
str_deque.add_front(item)
check_flag=Truewhilestr_deque.get_size() >1andcheck_flag:
left=str_deque.remove_front()   # 队尾移除right=str_deque.remove_tail()   # 队首移除ifleft!=right:   # 只要有一次不相等   不是回文check_flag=False# 判断完一遍   check_flag为True  是回文returncheck_flagprint(palindrome_check("radar"))
print(palindrome_check("abcbac"))
print(palindrome_check("上海自来水来自海上"))


目录
相关文章
|
5月前
|
机器学习/深度学习 监控 TensorFlow
使用Python实现深度学习模型:智能农业病虫害检测与防治
使用Python实现深度学习模型:智能农业病虫害检测与防治
303 65
|
4月前
|
机器学习/深度学习 数据采集 算法
时间序列结构变化分析:Python实现时间序列变化点检测
在时间序列分析和预测中,准确检测结构变化至关重要。新出现的分布模式往往会导致历史数据失去代表性,进而影响基于这些数据训练的模型的有效性。
359 1
|
3月前
|
机器学习/深度学习 TensorFlow 算法框架/工具
使用Python实现深度学习模型:智能质量检测与控制
使用Python实现深度学习模型:智能质量检测与控制 【10月更文挑战第8天】
322 62
使用Python实现深度学习模型:智能质量检测与控制
|
2月前
|
机器学习/深度学习 PyTorch TensorFlow
使用Python实现智能食品质量检测的深度学习模型
使用Python实现智能食品质量检测的深度学习模型
182 1
|
4月前
|
Docker Python 容器
python检测docker compose文件是否正确
python检测docker compose文件是否正确
|
4月前
|
机器学习/深度学习 数据采集 网络安全
使用Python实现深度学习模型:智能网络安全威胁检测
使用Python实现深度学习模型:智能网络安全威胁检测
355 5
|
4月前
|
编解码 Python Windows
python有没有包 可以检测 这个视频是否可以播放
python有没有包 可以检测 这个视频是否可以播放
|
3月前
|
运维 安全 网络协议
Python 网络编程:端口检测与IP解析
本文介绍了使用Python进行网络编程的两个重要技能:检查端口状态和根据IP地址解析主机名。通过`socket`库实现端口扫描和主机名解析的功能,并提供了详细的示例代码。文章最后还展示了如何整合这两部分代码,实现一个简单的命令行端口扫描器,适用于网络故障排查和安全审计。
62 0
|
3月前
|
数据处理 Python
Python读取大文件的“坑“与内存占用检测
Python读取大文件的“坑“与内存占用检测
93 0
|
3月前
|
安全 Java Python
基于python-django的Java网站全站漏洞检测系统
基于python-django的Java网站全站漏洞检测系统
42 0