LeetCode282周赛复盘

LeetCode282周赛复盘

博客首页:铁甲小宝同学

文章目的:周赛复盘

博主也在学习阶段,如若发现问题,请告知,非常感谢

同时也非常感谢各位小伙伴们的支持

每日一语:我未曾优秀过,但我未曾放弃过!

文章目录

    • LeetCode282周赛复盘
    • 前言
    • 第一题
    • 第二题
    • 第三题
    • 总结

前言

在今天上午博主也是参加了Leetcode的第282场周赛,通过本次周赛也发现了博主还有很多地方不足,需要继续去提升!’
先说说今天的战况:周赛开局倒是非常的顺利前十分钟拿下了第一和第二题,但是第三题卡了一小时无论怎么去优化都是超时(最后发现自己方法用错了),最后结束后发现第三题是通过二分法来进行求解,但是由于博主对二分法题量是比较少的。所以就没有往二分法上面去想。也就导致本次周赛被安排的明明白白。废话不多说了,我们下来看看本次的前三题吧(第四题还没摸到555555)

第一题

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

给你一个字符串数组 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



总结

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

你可能感兴趣的:(算法,算法,leetcode,职场和发展)