LeetCode简单题之仅执行一次字符串交换能否使两个字符串相等

news/2024/11/20 4:49:03/

题目

给你长度相等的两个字符串 s1 和 s2 。一次 字符串交换 操作的步骤如下:选出某个字符串中的两个下标(不必不同),并交换这两个下标所对应的字符。
如果对 其中一个字符串 执行 最多一次字符串交换 就可以使两个字符串相等,返回 true ;否则,返回 false 。
示例 1:
输入:s1 = “bank”, s2 = “kanb”
输出:true
解释:例如,交换 s2 中的第一个和最后一个字符可以得到 “bank”
示例 2:
输入:s1 = “attack”, s2 = “defend”
输出:false
解释:一次字符串交换无法使两个字符串相等
示例 3:
输入:s1 = “kelb”, s2 = “kelb”
输出:true
解释:两个字符串已经相等,所以不需要进行字符串交换
示例 4:
输入:s1 = “abcd”, s2 = “dcba”
输出:false
提示:
1 <= s1.length, s2.length <= 100
s1.length == s2.length
s1 和 s2 仅由小写英文字母组成
来源:力扣(LeetCode)

解题思路

  同时遍历两个字符串,标记不一样的字符下标,如果不一样的字符对超过了两对那么题目一定不成立,如果不一样的字符对只有一对也不会成立,如果没有不一样的字符,题目成立。如果恰恰只有两对不一样的字符对,那么判断交换后是否一样即可。

class Solution:def areAlmostEqual(self, s1: str, s2: str) -> bool:temp=[]for i in range(len(s1)):if s1[i]!=s2[i]:temp.append(i)if len(temp)==0: #如果没有不一样的字符return Trueelif len(temp)%2 or len(temp)>2: #如果仅有一对不同字符对或者超过两对return Falsereturn True if s1[temp[0]]==s2[temp[1]] and   s1[temp[1]]==s2[temp[0]] else False  #判断交换后是否一样

在这里插入图片描述


http://www.ppmy.cn/news/605683.html

相关文章

合肥工业大学—SQL Server数据库实验五:创建和删除索引

创建和删除索引1. 用SQL语句建立索引2. 用SQL语句删除索引Stuspno1. 用SQL语句建立索引 &#xff08;1&#xff09;应用场景&#xff1a;在教务管理系统中&#xff0c;经常需要通过学生的姓名查询学生的基本信息&#xff0c;学生人数大概在10000&#xff5e;20000人&#xff0…

LeetCode简单题之二叉搜索树的最小绝对差/最小距离

题目 给你一个二叉搜索树的根节点 root &#xff0c;返回 树中任意两不同节点值之间的最小差值 。 差值是一个正数&#xff0c;其数值等于两值之差的绝对值。 示例 1&#xff1a; 输入&#xff1a;root [4,2,6,1,3] 输出&#xff1a;1 示例 2&#xff1a; 输入&#xff1…

合肥工业大学—SQL Server数据库实验六:数据更新操作

数据更新操作1. 数据插入2. 数据修改3. 数据删除1. 数据插入 依次将准备好的数据用Insert Into语句将数据插入相应的基本表&#xff1a; 正确数据的插入&#xff0c;这些数据应该不会违反完整性约束注意基本表的先后插入顺序&#xff0c;体会参照完整性。特别要注意课程表的数据…

LeetCode简单题之区域和检索 - 数组不可变

题目 给定一个整数数组 nums&#xff0c;处理以下类型的多个查询: 计算索引 left 和 right &#xff08;包含 left 和 right&#xff09;之间的 nums 元素的 和 &#xff0c;其中 left < right 实现 NumArray 类&#xff1a; NumArray(int[] nums) 使用数组 nums 初始化对象…

合肥工业大学—SQL Server数据库实验七:数据查询

数据查询1. 单表查询2. 多表连接查询1. 单表查询 1. 查询全体学生的信息&#xff1b; -- 查询全体学生的信息 select * from student2. 根据专业编号&#xff08;21&#xff09;查询学生的学号、性别和年龄&#xff1b; -- 根据专业编号查询学生的学号、性别和年龄 select s…

LeetCode简单题之判断路径是否相交

题目 给你一个字符串 path&#xff0c;其中 path[i] 的值可以是 ‘N’、‘S’、‘E’ 或者 ‘W’&#xff0c;分别表示向北、向南、向东、向西移动一个单位。 你从二维平面上的原点 (0, 0) 处开始出发&#xff0c;按 path 所指示的路径行走。 如果路径在任何位置上与自身相交&…

Bert代码详解(一)重点详细

这是bert的pytorch版本&#xff08;与tensorflow一样的&#xff0c;这个更简单些&#xff0c;这个看懂了&#xff0c;tf也能看懂&#xff09;&#xff0c;地址&#xff1a;https://github.com/huggingface/pytorch-pretrained-BERT 主要内容在pytorch_pretrained_bert/modeling…