力扣每日一题 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:]

总结:

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

目录
相关文章
|
9月前
|
JSON 前端开发 JavaScript
js中await用法
js中await用法
183 0
|
存储 Android开发
[lcm] Qualcomm平台显示屏lcd添加I2C读取功能
1硬件设计分析采用IC 的I2C 功能读取ID 寄存器 2ARM9 更改GPIO 配置 3LK 添加代码 4LK 阶段不接屏不亮背光 5kernel 阶段不接屏不亮背光 6kernel 阶段I2C 配置 更多相关文章: 更多相关文章: 《高通Qualcom...
4023 0
|
9月前
|
存储 消息中间件 负载均衡
中间件常见问题
解决中间件问题的关键在于深入理解业务需求、系统架构和中间件的工作原理,然后结合实际情况进行针对性的优化和配置。同时,定期监控和评估中间件的性能和稳定性也是非常重要的。
164 3
|
测试技术 开发工具 git
推荐一个不错的弱网模拟框架
在《APP网络性能测试白皮书》中我们已经探讨了为什么要做弱网测试以及弱网测试中需要关注的一些指标,在《弱网环境搭建方案选型》这篇文章中我们讨论了各种弱网模拟方案的优缺点,其中在预算有限的情况下我是比较推荐基于ATC和树莓派去搭建弱网模拟平台的,这块的内容可以参考《树莓派搭建弱网测试环境全纪录(1)》和《树莓派搭建弱网测试环境全纪录(2)》,基于ATC的方案其实已经可以满足绝大部分场景的需求,但是原生的ATC方案易用性比较差,每次修改网络场景需要把被测APP置于后台,切换到网络模拟界面改参数,然后再切回被测APP,影响被测APP的操作连贯性,今天我要推荐的是一个基于ATC改造后的弱网模拟工具
530 0
推荐一个不错的弱网模拟框架
|
存储 机器学习/深度学习 人工智能
新入坑的SageMaker Studio Lab和Colab、Kaggle相比,性能如何?
新入坑的SageMaker Studio Lab和Colab、Kaggle相比,性能如何?
707 0
|
9月前
|
存储 前端开发 安全
快速了解std::promise的工作原理和使用
快速了解std::promise的工作原理和使用
243 3
|
网络协议 安全 Android开发
软件丨李跳跳们现在该如何跳呢?
前段时间,李跳跳等软件被某大厂发了律师函,之后,好些个跳广告软件都相继发布公众号说明,停止维护软件,并且下架了相关软件,那我们还能跳吗?该怎么跳呢?
654 0
软件丨李跳跳们现在该如何跳呢?
|
网络协议 Linux
虚拟机linux的ip和dns设置
今天弄了一天的虚拟机linux连接外网的问题.终于弄成功了。把问题都整理出来,以防以后忘记我安装的是redhat linux 5.4(64位).在安装的界面的时候,就配置了ip,子网掩码,网关,(没有配置DNS).
1139 0
|
存储 Python
python中argparse库,在B文件中如何调取A文件中的args参数,直接调用的方式
如果你想在 B 文件中导入 A 文件并直接访问其中的参数,那么需要注意以下两点: 1. 2. 在 A 文件中定义的参数必须是全局变量或者是可被外部访问的类属性或实例属性。否则,在 B 文件中无法直接访问这些参数。 3. 4. 如果 A 文件中定义了和 B 文件中相同名称的参数,那么在导入 A 文件之后,B 文件中的同名参数将被覆盖,导致访问到的值可能不是预期的值。
342 0

热门文章

最新文章