LeetCode 每日一题 2024/8/26-2024/9/1

记录了初步解题思路 以及本地实现代码;并不一定为最优 也希望大家能一起探讨 一起进步


目录

      • [8/26 690. 员工的重要性](#8/26 690. 员工的重要性)
      • [8/27 3134. 找出唯一性数组的中位数](#8/27 3134. 找出唯一性数组的中位数)
      • [8/28 3144. 分割字符频率相等的最少子字符串](#8/28 3144. 分割字符频率相等的最少子字符串)
      • [8/29 3142. 判断矩阵是否满足条件](#8/29 3142. 判断矩阵是否满足条件)
      • [8/30 3153. 所有数对中数位不同之和](#8/30 3153. 所有数对中数位不同之和)
      • 8/31
      • 9/1

8/26 690. 员工的重要性

BFS

python 复制代码
class Employee(object):
    def __init__(self, id, importance, subordinates):
        # It's the unique id of each node.
        # unique id of this employee
        self.id = id
        # the importance value of this employee
        self.importance = importance
        # the id of direct subordinates
        self.subordinates = subordinates
        
def getImportance(employees, id):
    """
    :type employees: Employee
    :type id: int
    :rtype: int
    """
    if len(employees)==0:
        return 0
    dic = {}
    for v in employees:
        dic[v.id] = v
    ret = 0
    l =[]
    l.append(id)
    while len(l)>0:
        n = l.pop(0)
        e = dic.get(n)
        ret += e.importance
        l.extend(e.subordinates)
    return ret

8/27 3134. 找出唯一性数组的中位数

共有m=1+2+...+n=n*(n+1)/2个费控连续子数组

中位数是第k=m//2个元素

对于一个子数组如果变长 它的不同元素个数不会变少

check(upper)检查小于upper数有多少个

python 复制代码
def medianOfUniquenessArray(nums):
    """
    :type nums: List[int]
    :rtype: int
    """
    import bisect
    from collections import defaultdict
    n=len(nums)
    k=(n*(n+1)//2+1)//2
    def check(upper):
        cnt = 0
        l = 0
        fre = defaultdict(int)
        for r,v in enumerate(nums):
            fre[v] +=1
            while len(fre)>upper:
                out = nums[l]
                fre[out]-=1
                if fre[out]==0:
                    del fre[out]
                l+=1
            cnt += r-l+1
            if cnt>=k:
                return True
        return False
    return bisect.bisect_left(range(len(set(nums))), True,1,key=check)

8/28 3144. 分割字符频率相等的最少子字符串

dp[i]记录以i结尾的前缀字符串最少平和字符串个数

对于每个i j从后往前遍历 m[x]存储字符x出现次数

对于子字符串s[j:i] 记录字符出现最大次数cnt

如果每个字符出现次数相同那么cnt*len(m)=字符串长度i-j+1

python 复制代码
def minimumSubstringsInPartition(s):
    """
    :type s: str
    :rtype: int
    """
    from collections import defaultdict
    n=len(s)
    dp = [float("inf")]*(n+1)
    dp[0]=0
    for i in range(1,n+1):
        m = defaultdict(int)
        cnt = 0
        for j in range(i,0,-1):
            m[s[j-1]]+=1
            cnt = max(cnt,m[s[j-1]])
            if cnt*len(m)==i-j+1 and dp[j-1]!=float("inf"):
                dp[i]=min(dp[i],dp[j-1]+1)
    return dp[n]

8/29 3142. 判断矩阵是否满足条件

判断第一行 相邻是否不同

判断每一列 是否相同

python 复制代码
def satisfiesConditions(grid):
    """
    :type grid: List[List[int]]
    :rtype: bool
    """
    n,m=len(grid),len(grid[0])
    for j in range(m):
        if j>0 and grid[0][j-1]==grid[0][j]:
            return False
        for i in range(1,n):
            if grid[i-1][j]!=grid[i][j]:
                return False
    return True

8/30 3153. 所有数对中数位不同之和

依次统计每一位上所有数值的个数

n=len(nums)

如果数值x出现m次 那么有n-m种情况会出现该位是不同的

累加最后因为重复计算除以二

python 复制代码
def sumDigitDifferences(nums):
    """
    :type nums: List[int]
    :rtype: int
    """
    n=len(nums)
    ans = 0
    while nums[0]>0:
        m = [0]*10
        for i in range(n):
            m[nums[i]%10]+=1
            nums[i]//=10
        for x in range(10):
            ans += (n-m[x])*m[x]
    return ans//2
            

8/31

python 复制代码

9/1

python 复制代码

相关推荐
LOnghas121129 分钟前
果园环境中道路与树木结构检测的YOLO11-Faster语义分割方法
python
Lips6111 小时前
2026.1.20力扣刷题笔记
笔记·算法·leetcode
2501_941329721 小时前
YOLOv8-LADH马匹检测识别算法详解与实现
算法·yolo·目标跟踪
洛生&1 小时前
Planets Queries II(倍增,基环内向森林)
算法
小郭团队2 小时前
1_6_五段式SVPWM (传统算法反正切+DPWM2)算法理论与 MATLAB 实现详解
嵌入式硬件·算法·matlab·dsp开发
小郭团队2 小时前
1_7_五段式SVPWM (传统算法反正切+DPWM3)算法理论与 MATLAB 实现详解
开发语言·嵌入式硬件·算法·matlab·dsp开发
鱼跃鹰飞2 小时前
Leetcode347:前K个高频元素
数据结构·算法·leetcode·面试
bybitq2 小时前
LeetCode236-二叉树的最近公共祖先(LCA)问题详解-C++
算法·深度优先
2501_944526422 小时前
Flutter for OpenHarmony 万能游戏库App实战 - 蜘蛛纸牌游戏实现
android·java·python·flutter·游戏
啊阿狸不会拉杆2 小时前
《数字图像处理》第 7 章 - 小波与多分辨率处理
图像处理·人工智能·算法·计算机视觉·数字图像处理