力扣题库——2591. 将钱分给最多的儿童

给定一定金额和儿童数量,需要按照特定规则分配,确保每个儿童至少有1美元且无人得到4美元。求解最多能有多少儿童得到8美元。示例展示了一种分配策略。当无法满足条件时返回-1。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述:

给你一个整数 money ,表示你总共有的钱数(单位为美元)和另一个整数 children ,表示你要将钱分配给多少个儿童。

你需要按照如下规则分配:

所有的钱都必须被分配。
每个儿童至少获得 1 美元。
没有人获得 4 美元。
请你按照上述规则分配金钱,并返回 最多 有多少个儿童获得 恰好 8 美元。如果没有任何分配方案,返回 -1 。

示例 1:

输入:money = 20, children = 3
输出:1
解释:
最多获得 8 美元的儿童数为 1 。一种分配方案为:
- 给第一个儿童分配 8 美元。
- 给第二个儿童分配 9 美元。
- 给第三个儿童分配 3 美元。
没有分配方案能让获得 8 美元的儿童数超过 1 。
示例 2:

输入:money = 16, children = 2
输出:2
解释:每个儿童都可以获得 8 美元。
 

提示:

1 <= money <= 200
2 <= children <= 30

题解:

 思路:if条件句列出所有情况:

可以把分配分两次进行:第一次:要求每个儿童至少要获得一美元,可以先每个儿童分配一美元,若此过程无法进行即money<children,则没有任何分配方案;第二次:想要求最终分配最多有多少儿童获得8美元也就等同于第二次最多有多少人再分得7美元,题目要求没有儿童获得4美元,也就是要求第二次没有人分配到3元;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值