Python算法题之“变位词”判断问题

2024-03-23 10:40

本文主要是介绍Python算法题之“变位词”判断问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

[TOC]

“变位词”判断问题

问题描述

所谓“变位词”是指两个词之间存在组成字母的重新排列关系

如:heart和earth,Python和typhon

为简单起见,假设参与判断的两个词仅由小写字母构成,而且长度相等

解题目标

写一个bool函数,以两个词作为参数,返回这两个词是否是变位词

解法一:逐字检查

解法思路

将词1中的字符逐个到词2中检查是否存在,存在就”打勾“标记(防止重复)

如果每个字符都能找到,那么这2个词就是变位词,只要有一个字符没有找到,就不是变位词

程序技巧

实现”打勾“标记:将词2对应字符设为None

由于字符串是不可变类型,需要先复制到列表中

v2-d3b9693d55ff5c704a892c128bf8969d_b.jpg


代码

        def abc(s1,s2):s2_list=list(s2)  # str转换为listpos1=0stillok = Truewhile pos1<len(s1) and stillok:  # 循环s1长度的次数pos2=0found = Falsewhile pos2<len(s2_list) and not found:  # 循环s2长度的次数if s1[pos1]==s2_list[pos2]:found=Trueelse:pos2=pos2+1if found:s2_list[pos2] = Noneelse:stillok=Falsepos1 = pos1+1return stillok
if __name__ == "__main__":zzz = abc("abcd","dcba")print(zzz)

解法二:排序比较

解题思路

  1. 将2个字符串先排序
  2. 对比是否相等

程序技巧

  1. str转list
  2. 进行排序
  3. list转str
  4. 进行比较
        def Method2(s1,s2):# 字符串是不可变的无法排序,str转listlist1=list(s1) list2=list(s2)# 进行排序list1.sort()list2.sort()# list 转 stra = ''.join(list1)b = ''.join(list2)# 进行比较if a==b:return Trueelse:return Falseif __name__ == "__main__":zzz2 = Method2('ablc','lcab')print(zzz2)

解法三:暴力法

解题思路

就是穷尽所有可能的组合

然后将s1中出现的字符进行全排序,再查看s2是否出现在全排列的列表中

这里就不附代码了,暴力法在这里恐怕不是一个好的算法

解法四:计数比较

解题思路

对比两个词中每个字符出现的次数,如果26个字母出现的次数都相同的话,那么这2个就是变位词

程序技巧

        def Method4(s1,s2):c1 = [0]* 26c2 = [0]* 26for i in range(len(s1)):pos = ord(s1[i])-ord('a')c1[pos] = c1[pos]+1for i in range(len(s2)):pos = ord(s2[i])-ord('a')c2[pos] = c2[pos]+1stillok =Truej=0while  stillok and j<26:if c1[j]!=c2[j]:stillok=Falsej+=1return stillok
if __name__ == "__main__":zzz4 = Method4('ablc','lcab')print(zzz4)

这个是四个解法中,性能最优的,T(n)=2n+26

这个解法中依赖额是2个长度为26的计数器列表,来保存字符计数,所以相对于之前3个算法来说,就需要了更多的空间,这里就是用空间换取了时间

这篇关于Python算法题之“变位词”判断问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/838060

相关文章

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

精选20个好玩又实用的的Python实战项目(有图文代码)

《精选20个好玩又实用的的Python实战项目(有图文代码)》文章介绍了20个实用Python项目,涵盖游戏开发、工具应用、图像处理、机器学习等,使用Tkinter、PIL、OpenCV、Kivy等库... 目录① 猜字游戏② 闹钟③ 骰子模拟器④ 二维码⑤ 语言检测⑥ 加密和解密⑦ URL缩短⑧ 音乐播放

python panda库从基础到高级操作分析

《pythonpanda库从基础到高级操作分析》本文介绍了Pandas库的核心功能,包括处理结构化数据的Series和DataFrame数据结构,数据读取、清洗、分组聚合、合并、时间序列分析及大数据... 目录1. Pandas 概述2. 基本操作:数据读取与查看3. 索引操作:精准定位数据4. Group

Python pandas库自学超详细教程

《Pythonpandas库自学超详细教程》文章介绍了Pandas库的基本功能、安装方法及核心操作,涵盖数据导入(CSV/Excel等)、数据结构(Series、DataFrame)、数据清洗、转换... 目录一、什么是Pandas库(1)、Pandas 应用(2)、Pandas 功能(3)、数据结构二、安

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

Python安装Pandas库的两种方法

《Python安装Pandas库的两种方法》本文介绍了三种安装PythonPandas库的方法,通过cmd命令行安装并解决版本冲突,手动下载whl文件安装,更换国内镜像源加速下载,最后建议用pipli... 目录方法一:cmd命令行执行pip install pandas方法二:找到pandas下载库,然后

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

Python标准库之数据压缩和存档的应用详解

《Python标准库之数据压缩和存档的应用详解》在数据处理与存储领域,压缩和存档是提升效率的关键技术,Python标准库提供了一套完整的工具链,下面小编就来和大家简单介绍一下吧... 目录一、核心模块架构与设计哲学二、关键模块深度解析1.tarfile:专业级归档工具2.zipfile:跨平台归档首选3.

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3