力扣每日一题 6/3

简介: 力扣每日一题 6/3

1103.分糖果II[简单]

题目:

排排坐,分糖果。

我们买了一些糖果 candies,打算把它们分给排好队的 n = num_people 个小朋友。

给第一个小朋友 1 颗糖果,第二个小朋友 2 颗,依此类推,直到给最后一个小朋友 n 颗糖果。

然后,我们再回到队伍的起点,给第一个小朋友 n + 1 颗糖果,第二个小朋友 n + 2 颗,依此类推,直到给最后一个小朋友 2 * n 颗糖果。

重复上述过程(每次都比上一次多给出一颗糖果,当到达队伍终点后再次从队伍起点开始),直到我们分完所有的糖果。注意,就算我们手中的剩下糖果数不够(不比前一次发出的糖果多),这些糖果也会全部发给当前的小朋友。返回一个长度为 num_people、元素之和为 candies 的数组,以表示糖果的最终分发情况(即 ans[i] 表示第 i 个小朋友分到的糖果数)。

示例 1:

输入:candies = 7, num_people = 4

输出:[1,2,3,1]

解释:

第一次,ans[0] += 1,数组变为 [1,0,0,0]。

第二次,ans[1] += 2,数组变为 [1,2,0,0]。

第三次,ans[2] += 3,数组变为 [1,2,3,0]。

第四次,ans[3] += 1(因为此时只剩下 1 颗糖果),最终数组变为 [1,2,3,1]。


例 2:

输入:candies = 10, num_people = 3

输出:[5,2,3]

解释:

第一次,ans[0] += 1,数组变为 [1,0,0]。

第二次,ans[1] += 2,数组变为 [1,2,0]。

第三次,ans[2] += 3,数组变为 [1,2,3]。

第四次,ans[0] += 4,最终数组变为 [5,2,3]。

提示:

  • 1 <= candies <= 10^9
  • 1 <= num_people <= 1000

题目分析:

        这道题直接可以暴力模拟,然后取模记录数据,加到dp列表里面,然后返回dp列表就可以了。

代码实现:

class Solution:
    def distributeCandies(self, candies: int, num_people: int) -> List[int]:
        a=1
        dp=[0]*(num_people+1)
        n=1
        dp[1]=1
        while a<=candies:
            n+=1
            if n%num_people==0:
                h=num_people
            else: h=n%num_people
            a=((n+1)*(n+2))//2  # 预测下一个
            dp[h]+=n
        ch=candies-(n*(n+1))//2
        if h!=num_people:
            dp[h+1]+=ch
        else:
            dp[1]+=ch
        return dp[1:]

总结:

        这段代码可以实现将指定数量的糖果分给指定数量的人。它通过一个循环来逐步分发糖果,直到所有糖果都被分完。然后调整分发列表以考虑可能的剩余糖果,并返回最终的分发列表。

目录
相关文章
|
7月前
|
存储 vr&ar Python
力扣每日一题 6/5
力扣每日一题 6/5
50 3
|
7月前
|
索引
力扣每日一题 5/25
力扣每日一题 5/25
43 2
|
7月前
|
存储
力扣每日一题 6/9
力扣每日一题 6/9
50 5
|
7月前
|
存储 人工智能 算法
力扣每日一题 6/4
力扣每日一题 6/4
46 3
|
7月前
力扣每日一题 6/7
力扣每日一题 6/7
42 3
|
7月前
力扣每日一题 6/1
力扣每日一题 6/1
48 3
|
7月前
|
Python
力扣每日一题 5/30
力扣每日一题 5/30
40 3
|
7月前
力扣每日一题 6/2
力扣每日一题 6/2
47 3
|
7月前
|
算法
力扣每日一题 6/6
力扣每日一题 6/6
49 3
|
7月前
力扣每日一题 5/29
力扣每日一题 5/29
41 3