LeetCode282周赛复盘

简介: LeetCode282周赛复盘

第一题

统计包含给定前缀的字符串


给你一个字符串数组 words 和一个字符串 pref 。


返回 words 中以 pref 作为 前缀 的字符串的数目。


字符串 s 的 前缀 就是 s 的任一前导连续字符串。


示例 1:


输入:words = [“pay”,“attention”,“practice”,“attend”], pref = “at” 输出:2


解释:以 “at” 作为前缀的字符串有两个,分别是:“attention” 和 “attend” 。


思路:

本题就是一个简单的for循环遍历,具体的流程博主也是相信各位小伙伴都是掌握的。


代码:


class Solution:
    def prefixCount(self, words: List[str], pref: str) -> int:
        res = 0
        x = len(pref)
        for i in words:
            if len(i) >= x:
                if i[:x] == pref:
                    res += 1
        return res


第二题

使用两字符串互为字母异位词的最少步骤数


题目:


给你一个数组 time ,其中 time[i] 表示第 i 辆公交车完成 一趟旅途 所需要花费的时间。


每辆公交车可以 连续 完成多趟旅途,也就是说,一辆公交车当前旅途完成后,可以 立马开始 下一趟旅途。每辆公交车 独立 运行,也就是说可以同时有多辆公交车在运行且互不影响。


给你一个整数 totalTrips ,表示所有公交车 总共 需要完成的旅途数目。请你返回完成 至少 totalTrips 趟旅途需要花费的 最少 时间。


示例 1:


输入:time = [1,2,3], totalTrips = 5

输出:3

解释:


时刻 t = 1 ,每辆公交车完成的旅途数分别为 [1,0,0] 。

已完成的总旅途数为 1 + 0 + 0 = 1 。

时刻 t = 2 ,每辆公交车完成的旅途数分别为 [2,1,0] 。

已完成的总旅途数为 2 + 1 + 0 = 3 。

时刻 t = 3 ,每辆公交车完成的旅途数分别为 [3,1,1] 。

已完成的总旅途数为 3 + 1 + 1 = 5 。

所以总共完成至少 5 趟旅途的最少时间为 3 。

思路:


本题其实就是一个简单的hash表的问题,就是把两个字符中不同的字符个数和相同字符不同数量的字符个数相加即可求出本题。


由于时间问题本题博主没有优化,直接ac的也能过的。


class Solution:
    def minSteps(self, s: str, t: str) -> int:
        res = 0
        dit1 = {}
        dit2 = {}
        for i in s:
            if i not in dit1:
                dit1[i] = 1
            else:
                dit1[i] += 1
        for j in t:
            if j not  in dit2:
                dit2[j] = 1
            else:
                dit2[j] += 1
        for i in dit1:
            if i not in dit2:
                res += dit1[i]
            elif dit1[i] != dit2[i]:
                res += abs(dit1[i] - dit2[i])
        for i in dit2:
            if i not in dit1:
                res += dit2[i]
        return  res






第三题

完成旅途的最少时间


题目:


给你一个数组 time ,其中 time[i] 表示第 i 辆公交车完成 一趟旅途 所需要花费的时间。


每辆公交车可以 连续 完成多趟旅途,也就是说,一辆公交车当前旅途完成后,可以 立马开始 下一趟旅途。每辆公交车 独立 运行,也就是说可以同时有多辆公交车在运行且互不影响。


给你一个整数 totalTrips ,表示所有公交车 总共 需要完成的旅途数目。请你返回完成 至少 totalTrips 趟旅途需要花费的 最少 时间。


示例 1:


输入:time = [1,2,3], totalTrips = 5

输出:3

解释:


时刻 t = 1 ,每辆公交车完成的旅途数分别为 [1,0,0] 。

已完成的总旅途数为 1 + 0 + 0 = 1 。

时刻 t = 2 ,每辆公交车完成的旅途数分别为 [2,1,0] 。

已完成的总旅途数为 2 + 1 + 0 = 3 。

时刻 t = 3 ,每辆公交车完成的旅途数分别为 [3,1,1] 。

已完成的总旅途数为 3 + 1 + 1 = 5 。

所以总共完成至少 5 趟旅途的最少时间为 3

思路:


本题是比较经典的二分查找。因为花费时间是不会超过min(time)*totalTrips,所以我们可以以其为右边界,以0为左边界,然后使用二分查找判断mid时间时完成的次数是大于还是小于totalTrips进行搜索。如果小于则会让左边界等于mid+1,反之右边界等于mid - 1。具体流程我们能看具体代码。


代码:


class Solution:
    def minimumTime(self, time: List[int], totalTrips: int) -> int:
        time.sort()
        l,r=0,time[0]*totalTrips
        while l<r:
            mid=1+(l+r)//2
            tmp=0
            for i in time:
                tmp+=mid//i
            if tmp<totalTrips:
                l=mid
            else:
                r=mid-1
        return l+1




总结

每次通过力扣的周赛都能对自己近一段的算法水平进行检验,通过这次周赛博主也能发现自己的查找算法是一个十分大的弱项。所以下一段时间准备去复习复习查找和排序这些经典算法了哈哈哈(毕竟这些都是面试常考的问题哦)。



相关文章
|
21天前
|
Go
golang力扣leetcode 第 291 场周赛
golang力扣leetcode 第 291 场周赛
41 0
|
21天前
|
Go vr&ar
golang力扣leetcode 第 288 场周赛
golang力扣leetcode 第 288 场周赛
36 0
|
21天前
|
Go
golang力扣leetcode 第 286 场周赛
golang力扣leetcode 第 286 场周赛
39 0
|
21天前
|
Go
golang力扣leetcode第 294 场周赛
golang力扣leetcode第 294 场周赛
35 0
|
21天前
|
算法 Java Go
golang力扣leetcode 第 293 场周赛
golang力扣leetcode 第 293 场周赛
61 0
|
21天前
|
Go
golang力扣leetcode 第 290 场周赛
golang力扣leetcode 第 290 场周赛
29 0
|
21天前
|
Go C++
golang力扣leetcode 第 284 场周赛
golang力扣leetcode 第 284 场周赛
42 0
|
8月前
|
算法 Android开发
LeetCode 周赛上分之旅 #48 一道简单的树上动态规划问题
学习数据结构与算法的关键在于掌握问题背后的算法思维框架,你的思考越抽象,它能覆盖的问题域就越广,理解难度也更复杂。在这个专栏里,小彭与你分享每场 LeetCode 周赛的解题报告,一起体会上分之旅。
48 1
|
21天前
|
Go
golang力扣leetcode 第 292 场周赛
golang力扣leetcode 第 292 场周赛
42 0
|
21天前
|
存储
Leetcode第382场周赛
```markdown 给定字符串`s`,计算按键变更次数,即使用不同键的次数,不考虑大小写差异。例如,`&quot;aAbBcC&quot;`变更了2次。函数`countKeyChanges`实现此功能。另外,求满足特定模式子集最大元素数,`maximumLength`函数使用`TreeMap`统计次数,枚举并构建子集,返回最大长度。最后,Alice和Bob玩鲜花游戏,Alice要赢需满足鲜花总数奇数、顺时针在[1,n]、逆时针在[1,m],返回满足条件的(x, y)对数,可通过奇偶性分类讨论求解。 ```
15 1