leetcode学习笔记2

文章目录

  • [1. 关于处理字符串的](#1. 关于处理字符串的)
    • [1.1 删列造序 II](#1.1 删列造序 II)

1. 关于处理字符串的

1.1 删列造序 II

原题链接为:955. 删列造序 II,我至少提交了6次,都提交失败,最后看的是官方题解,官方的题解真的很不错,具体使用all 函数和zip函数。定义了一个数组cuts,其长度为strs的长度减一,用于表示两两字符串在删除一些字符的基础上是否符合题目要求。参考代码如下:

python 复制代码
class Solution:
    def minDeletionSize(self, A):
        # cuts[i] is True : we don't need to check col[i] <= col[i+1]
        cuts = [False] * (len(A) - 1)
        ans = 0
        for col in zip(*A):
            if all(cuts[i] or col[i] <= col[i + 1] for i in range(len(col) - 1)):
                for i in range(len(col) - 1):
                    if col[i] < col[i + 1]:
                        cuts[i] = True
            else:
                ans += 1
        return ans

个人觉得这里可以添加一个判断语句,从而提高代码运行效率。毕竟如果代码运行到某一列字符时,两两字符串如果已经是col[i] < col[i + 1],也就是此时all(cuts)结果为True,此时可以直接结束for循环。改进代码如下:

python 复制代码
class Solution:
    def minDeletionSize(self, A):
        # cuts[i] is True : we don't need to check col[i] <= col[i+1]
        cuts = [False] * (len(A) - 1)
        ans = 0
        for col in zip(*A):
            if all(cuts[i] or col[i] <= col[i + 1] for i in range(len(col) - 1)):
                for i in range(len(col) - 1):
                    if col[i] < col[i + 1]:
                        cuts[i] = True
                if all(cuts):
                    break
            else:
                ans += 1
        return ans

可以看到改进一下,效率高了一些。。这道题目很新颖吧,如果之后碰到类似题目,希望到时候我能及时想到这道题目解题思路。

相关推荐
love在水一方1 小时前
VLN 入门学习计划 —— 基于 InternNav
学习
糖炒栗子03261 小时前
【笔记】高分卫星影像 TIF 切片处理
笔记
Nice_Fold1 小时前
Kubernetes DaemonSet、StatefulSet与Service(自用笔记)
笔记·容器·kubernetes
_深海凉_2 小时前
LeetCode热题100-寻找两个正序数组的中位数
算法·leetcode·职场和发展
踩坑记录3 小时前
leetcode hot100 寻找两个正序数组的中位数 hard 二分查找 双指针
leetcode
red_redemption4 小时前
自由学习记录(175)
学习
ZhiqianXia4 小时前
《The Design of Design》阅读笔记
前端·笔记·microsoft
nashane4 小时前
HarmonyOS 6学习:画中画(PiP)状态同步与场景化实战指南
学习·pip·harmonyos·harmonyos 5
祁白_5 小时前
nmap工具笔记整理
笔记·web安全·测试
_李小白5 小时前
【android opencv学习笔记】Day 8: remap(像素位置重映射)
android·opencv·学习