LeetCode 每日一题 2024/10/14-2024/10/20

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


目录

      • [10/14 887. 鸡蛋掉落](#10/14 887. 鸡蛋掉落)
      • [10/15 3200. 三角形的最大高度](#10/15 3200. 三角形的最大高度)
      • [10/16 3194. 最小元素和最大元素的最小平均值](#10/16 3194. 最小元素和最大元素的最小平均值)
      • [10/17 3193. 统计逆序对的数目](#10/17 3193. 统计逆序对的数目)
      • [10/18 3191. 使二进制数组全部等于 1 的最少操作次数 I](#10/18 3191. 使二进制数组全部等于 1 的最少操作次数 I)
      • [10/19 3192. 使二进制数组全部等于 1 的最少操作次数 II](#10/19 3192. 使二进制数组全部等于 1 的最少操作次数 II)
      • [10/20 908. 最小差值 I](#10/20 908. 最小差值 I)

10/14 887. 鸡蛋掉落

动态规划

1.dp[K][N]代表K个鸡蛋 N层最坏情况的最少次数

2.dp[k][m]=n k个鸡蛋 可以扔m次 最坏情况下最多可以测n层楼

dp[k][m] = 1+ dp[k,m-1]#没碎+dp[k-1,m-1]#碎了

python 复制代码
def superEggDrop(K, N):
    """
    :type K: int
    :type N: int
    :rtype: int
    """
    mem={}
    def dp(K,N):
        if K==1:
            return N
        if N==0:
            return 0
        if (K,N) in mem:
            return mem[(K,N)]
        res = float('INF')
        lo,hi=1,N
        while lo<=hi:
            mid=lo+(hi-lo)//2
            broken = dp(K-1,mid-1) #碎了
            not_broken = dp(K,N-mid),  #没碎
            if broken>not_broken:
                hi = mid -1
                res = min(res,broken+1)
            else:
                lo = mid+1
                res = min(res,not_broken+1)
        
        mem[(K,N)]=res
        return res
    
    return dp(K,N)

def superEggDrop2(K, N):
    """
    :type K: int
    :type N: int
    :rtype: int
    """
    dp = [[0]*(N+1) for _ in range(K+1)]
    m = 0
    while dp[K][m]<N:
        m+=1
        for k in range(1,K+1):
            dp[k][m] = dp[k][m-1] + dp[k-1][m-1]+1
    return m

10/15 3200. 三角形的最大高度

分别判断红、蓝先放第一排的两种情况

python 复制代码
def maxHeightOfTriangle(red, blue):
    """
    :type red: int
    :type blue: int
    :rtype: int
    """
    def check(odd,even):
        cur = 1
        while True:
            print(odd,even,cur)
            if cur%2==1:
                if odd>=cur:
                    odd-=cur
                else:
                    break
            else:
                if even>=cur:
                    even-=cur
                else:
                    break
            cur+=1
        return cur-1
    return max(check(red,blue),check(blue,red))

10/16 3194. 最小元素和最大元素的最小平均值

从小到大排列 依次求平均值

python 复制代码
def minimumAverage(nums):
    """
    :type nums: List[int]
    :rtype: float
    """
    nums.sort()
    ans = nums[-1]
    n=len(nums)
    for i in range(n//2):
        ans = min(ans,(nums[i]+nums[n-1-i])*1.0/2)
    return ans

10/17 3193. 统计逆序对的数目

https://leetcode.cn/problems/count-the-number-of-inversions/solutions/2946689/tong-ji-ni-xu-dui-de-shu-mu-by-leetcode-qsk7r/?envType=daily-question\&envId=2024-10-18

python 复制代码
def numberOfPermutations(n, requirements):
    """
    :type n: int
    :type requirements: List[List[int]]
    :rtype: int
    """
    MOD=10**9+7
    req = {0:0}
    for end,cnt in requirements:
        req[end]=cnt
    if req[0]>0:
        return 0
    
    mem = {}
    def dfs(end,cnt):
        ans = 0
        if (end,cnt) in mem:
            return mem[(end,cnt)]
        if cnt<0:
            return 0
        if end==0:
            return 1
        if end-1 in req:
            r = req[end-1]
            if r<=cnt<=end+r:
                ans = dfs(end-1,r)
                mem[(end,cnt)]=ans
                return ans
            else:
                mem[(end,cnt)]=ans
                return ans
        else:
            if cnt>end:
                ans = (dfs(end,cnt-1)-dfs(end-1,cnt-1-end)+dfs(end-1,cnt))%MOD
                mem[(end,cnt)]=ans
                return ans
            else:
                ans = (dfs(end,cnt-1) + dfs(end-1,cnt)) % MOD
                mem[(end,cnt)]=ans
                return ans
    return dfs(n-1,req[n-1])

10/18 3191. 使二进制数组全部等于 1 的最少操作次数 I

对于同个位置起始的操作两次等于没有操作 所以每个位置起始的操作最多1次

对不同的几个操作 顺序并不会改变最后的操作结果

所以从左到右操作即可

从头到尾遍历 遇到0进行翻转

最后查看数组最后两位是否为1

python 复制代码
def minOperations(nums):
    """
    :type nums: List[int]
    :rtype: int
    """
    ans=0
    for i in range(len(nums)-2):
        if nums[i]==0:
            nums[i+1]^=1
            nums[i+2]^=1
            ans+=1
    return ans if nums[-1] and nums[-2] else -1
    
        

10/19 3192. 使二进制数组全部等于 1 的最少操作次数 II

最左侧的0必须进行反转操作

为了使得反转次数最少 从左至右依次判断

遇到0就需要反转

python 复制代码
def minOperations(nums):
    """
    :type nums: List[int]
    :rtype: int
    """
    ans = 0
    for num in nums:
        if (num+ans)%2==0:
            ans+=1
    return ans

10/20 908. 最小差值 I

找到当前最大值a 最小值 b

a可以减小k b可以增加k

a-b的差值最多可以减少2k

python 复制代码
def smallestRangeI(nums, k):
    """
    :type nums: List[int]
    :type k: int
    :rtype: int
    """
    return max(0,max(nums)-min(nums)-2*k)

相关推荐
XH华1 小时前
初识C语言之二维数组(下)
c语言·算法
南宫生2 小时前
力扣-图论-17【算法学习day.67】
java·学习·算法·leetcode·图论
不想当程序猿_2 小时前
【蓝桥杯每日一题】求和——前缀和
算法·前缀和·蓝桥杯
落魄君子2 小时前
GA-BP分类-遗传算法(Genetic Algorithm)和反向传播算法(Backpropagation)
算法·分类·数据挖掘
菜鸡中的奋斗鸡→挣扎鸡2 小时前
滑动窗口 + 算法复习
数据结构·算法
Lenyiin2 小时前
第146场双周赛:统计符合条件长度为3的子数组数目、统计异或值为给定值的路径数目、判断网格图能否被切割成块、唯一中间众数子序列 Ⅰ
c++·算法·leetcode·周赛·lenyiin
郭wes代码3 小时前
Cmd命令大全(万字详细版)
python·算法·小程序
scan7243 小时前
LILAC采样算法
人工智能·算法·机器学习
菌菌的快乐生活3 小时前
理解支持向量机
算法·机器学习·支持向量机
大山同学3 小时前
第三章线性判别函数(二)
线性代数·算法·机器学习