前缀和+后缀和算法模板-附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
相关文章
|
8天前
|
算法
|
5月前
|
算法
【算法】前缀和——二维前缀和模板题
【算法】前缀和——二维前缀和模板题
|
3月前
|
机器学习/深度学习 人工智能 自然语言处理
【MM2024】阿里云 PAI 团队图像编辑算法论文入选 MM2024
阿里云人工智能平台 PAI 团队发表的图像编辑算法论文在 MM2024 上正式亮相发表。ACM MM(ACM国际多媒体会议)是国际多媒体领域的顶级会议,旨在为研究人员、工程师和行业专家提供一个交流平台,以展示在多媒体领域的最新研究成果、技术进展和应用案例。其主题涵盖了图像处理、视频分析、音频处理、社交媒体和多媒体系统等广泛领域。此次入选标志着阿里云人工智能平台 PAI 在图像编辑算法方面的研究获得了学术界的充分认可。
【MM2024】阿里云 PAI 团队图像编辑算法论文入选 MM2024
|
3月前
|
机器学习/深度学习 人工智能 算法
【MM2024】面向 StableDiffusion 的多目标图像编辑算法 VICTORIA
阿里云人工智能平台 PAI 团队与华南理工大学合作在国际多媒体顶级会议 ACM MM2024 上发表 VICTORIA 算法,这是一种面向 StableDiffusion 的多目标图像编辑算法。VICTORIA 通过文本依存关系来修正图像编辑过程中的交叉注意力图,从而确保关系对象的一致性,支持用户通过修改描述性提示一次性编辑多个目标。
|
4月前
|
存储 算法 Java
前缀和算法
本文介绍了前缀和及其变种在解决区间求和问题中的应用。首先,一维前缀和可通过预处理数组快速求得任意区间的和。接着,二维前缀和扩展了这一思想,适用于矩阵操作。此外,文章探讨了如何利用前缀和解决诸如“寻找数组中心下标”、“除自身以外数组的乘积”等问题,并进一步讲解了涉及哈希表优化的“和为 K 的子数组”等相关题目。最后,通过实例展示了如何在矩阵中高效计算特定区域的元素之和。文中包含代码示例与图解说明,便于理解。
55 0
前缀和算法
|
3月前
|
人工智能 算法 C++
一篇带你速通前缀和算法(C/C++)
一篇带你速通前缀和算法(C/C++)
|
5月前
|
开发者 索引 Python
这些年背过的面试题——LeetCode
本文是技术人面试系列LeetCode篇,一文带你详细了解,欢迎收藏!
|
5月前
|
算法 C++
【算法】前缀和算法——和可被K整除的子数组
【算法】前缀和算法——和可被K整除的子数组
|
5月前
|
算法
【算法】前缀和算法——和为k的子数组之和
【算法】前缀和算法——和为k的子数组之和
|
5月前
|
算法
【算法】前缀和——除自身以外数组的乘积
【算法】前缀和——除自身以外数组的乘积

热门文章

最新文章