前缀和+后缀和算法模板-附LeetCode习题-面试题 01.05. 一次编辑

简介: 前缀和+后缀和算法模板-附LeetCode习题-面试题 01.05. 一次编辑

面试题 01.05. 一次编辑


难度中等142收藏分享切换为英文接收动态反馈


字符串有三种编辑操作:插入一个字符、删除一个字符或者替换一个字符。 给定两个字符串,编写一个函数判定它们是否只需要一次(或者零次)编辑。


示例 1:


输入:

first = "pale"

second = "ple"

输出: True

示例 2:


输入:

first = "pales"

second = "pal"

输出: False

通过次数47,199提交次数142,718


解题思路:

如果两个字符串符合要求,那么他的前缀和 and 后缀和应该是相等的。


Python代码:

 

class Solution:
    def oneEditAway(self, first: str, second: str) -> bool:
        p1 , p2 , q1 , q2 = 0 , 0 , len(first)-1 , len(second)-1
        while p1<=q1 and p2<=q2:
            if first[p1]==second[p2]:
                p1 += 1
                p2 += 1
                continue
            elif first[q1]==second[q2]:
                q1 -= 1
                q2 -= 1
            else: break
        return q1-p1 + q2-p2<=0 and abs(p1-p2)<=1 and abs(q1-q2)<=1

C++代码:

class Solution {
public:
    bool oneEditAway(string first, string second) {
        int p1 = 0 , p2 = 0;
        int q1 = first.size()-1 , q2 = second.size()-1;
        while (p1<=q1 && p2<=q2)
        {
            if (first[p1]==second[p2]){
                p1++;
                p2++;
                continue;
            }
            else if (first[q1] == second[q2]){
                q1--;
                q2--;
            }
            else break;
        }
        return q1-p1 + q2-p2 <=0 && abs(p2-p1)<=1 && abs(q2-q1)<=1;
    }
};

python的快速解法:

class Solution:
    def oneEditAway(self, first: str, second: str) -> bool:
        m , n = len(first) , len(second)
        if m-n>1:return False
        if m<n:return self.oneEditAway(second , first)
        for i , (x , y) in enumerate(zip(first , second)):
           if x!=y:
               return first[i+1:]==second[i+1:] if m==n else first[i+1:]==second[i:]
        return True
相关文章
|
3月前
|
算法
Leetcode 初级算法 --- 数组篇
Leetcode 初级算法 --- 数组篇
55 0
|
13天前
|
存储 算法 测试技术
【C++数据结构——树】二叉树的遍历算法(头歌教学实验平台习题) 【合集】
本任务旨在实现二叉树的遍历,包括先序、中序、后序和层次遍历。首先介绍了二叉树的基本概念与结构定义,并通过C++代码示例展示了如何定义二叉树节点及构建二叉树。接着详细讲解了四种遍历方法的递归实现逻辑,以及层次遍历中队列的应用。最后提供了测试用例和预期输出,确保代码正确性。通过这些内容,帮助读者理解并掌握二叉树遍历的核心思想与实现技巧。
37 2
|
27天前
|
算法
|
2月前
|
存储 算法 Java
leetcode算法题-有效的括号(简单)
【11月更文挑战第5天】本文介绍了 LeetCode 上“有效的括号”这道题的解法。题目要求判断一个只包含括号字符的字符串是否有效。有效字符串需满足左括号必须用相同类型的右括号闭合,并且左括号必须以正确的顺序闭合。解题思路是使用栈数据结构,遍历字符串时将左括号压入栈中,遇到右括号时检查栈顶元素是否匹配。最后根据栈是否为空来判断字符串中的括号是否有效。示例代码包括 Python 和 Java 版本。
|
3月前
|
算法 Java 数据库
美团面试:百亿级分片,如何设计基因算法?
40岁老架构师尼恩分享分库分表的基因算法设计,涵盖分片键选择、水平拆分策略及基因法优化查询效率等内容,助力面试者应对大厂技术面试,提高架构设计能力。
美团面试:百亿级分片,如何设计基因算法?
|
3月前
|
算法 前端开发 Java
数据结构与算法学习四:单链表面试题,新浪、腾讯【有难度】、百度面试题
这篇文章总结了单链表的常见面试题,并提供了详细的问题分析、思路分析以及Java代码实现,包括求单链表中有效节点的个数、查找单链表中的倒数第k个节点、单链表的反转以及从尾到头打印单链表等题目。
46 1
数据结构与算法学习四:单链表面试题,新浪、腾讯【有难度】、百度面试题
|
2月前
|
算法 安全 NoSQL
2024重生之回溯数据结构与算法系列学习之顺序表习题精讲【无论是王道考研人还真爱粉都能包会的;不然别给我家鸽鸽丢脸好嘛?】
顺序表的定义和基本操作之插入;删除;按值查找;按位查找习题精讲等具体详解步骤以及举例说明
|
3月前
|
机器学习/深度学习 算法 Java
机器学习、基础算法、python常见面试题必知必答系列大全:(面试问题持续更新)
机器学习、基础算法、python常见面试题必知必答系列大全:(面试问题持续更新)
|
3月前
|
算法
每日一道算法题(Leetcode 20)
每日一道算法题(Leetcode 20)
40 2
|
3月前
|
算法 Java 数据库
美团面试:百亿级分片,如何设计基因算法?
40岁老架构师尼恩在读者群中分享了关于分库分表的基因算法设计,旨在帮助大家应对一线互联网企业的面试题。文章详细介绍了分库分表的背景、分片键的设计目标和建议,以及基因法的具体应用和优缺点。通过系统化的梳理,帮助读者提升架构、设计和开发水平,顺利通过面试。
美团面试:百亿级分片,如何设计基因算法?

热门文章

最新文章