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. 分割字符频率相等的最少子字符串

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

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

对于子字符串sj: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 复制代码

相关推荐
PAK向日葵11 小时前
从零实现 Python 虚拟机(一):PVM 基本原理介绍
python
神所夸赞的夏天11 小时前
创建虚拟环境提示SSLError错误
python
极光代码工作室12 小时前
基于机器学习的二手商品价格预测系统
人工智能·python·深度学习·机器学习
无情的西瓜皮12 小时前
MCP协议实战:从零搭建一个AI Agent工具服务器
运维·服务器·python
叁散12 小时前
ESP32 LCD1602显示实验报告
算法
过期动态12 小时前
【LeetCode 热题 100】盛最多水的容器
java·数据结构·spring boot·算法·leetcode·spring cloud·职场和发展
IT策士12 小时前
Django 从 0 到 1 打造完整电商平台:系列总结 + 项目演示与后续扩展
后端·python·django
凌波粒12 小时前
LeetCode--700.二叉搜索树中的搜索(二叉树)
算法·leetcode·职场和发展
君为先-bey12 小时前
LeMiCa——基于扩散模型的高效视频生成的词典序最小化路径缓存
python·算法·机器学习·扩散模型
L_cl13 小时前
大模型应用开发 9.FastAPI ① 请求与响应
python·fastapi