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

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

相关推荐
1104.北光c°1 小时前
滑动窗口HotKey探测机制:让你的缓存TTL更智能
java·开发语言·笔记·程序人生·算法·滑动窗口·hotkey
默默开发2 小时前
完整版:本地电脑 + WiFi 搭建 AI 自动炒股 + 自我学习系统
人工智能·学习·电脑
for_ever_love__2 小时前
Objective-C学习 NSSet 和 NSMutableSet 功能详解
开发语言·学习·ios·objective-c
盐水冰10 小时前
【烘焙坊项目】后端搭建(12) - 订单状态定时处理,来单提醒和顾客催单
java·后端·学习
Hello小赵10 小时前
视频压缩编码学习(一)—— 基础知识大集合
学习
左左右右左右摇晃10 小时前
计算机网络笔记整理
笔记·计算机网络
不吃西红柿的8510 小时前
[职场] 内容运营求职简历范文 #笔记#职场发展
笔记·职场和发展·内容运营
似水明俊德11 小时前
02-C#.Net-反射-学习笔记
开发语言·笔记·学习·c#·.net
智者知已应修善业11 小时前
【51单片机独立按键控制数码管移动反向,2片74CH573/74CH273段和位,按键按下保持原状态】2023-3-25
经验分享·笔记·单片机·嵌入式硬件·算法·51单片机
adore.96812 小时前
3.18 复试学习
学习