- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我很难弄清楚如何有效地解决这个问题。让我描述一下它是如何进行的:
“一位辛勤工作的妈妈为她的三个 child Amelia、Jessica 和 Bruno 买了几种营养值(value)不同的水果。两个女孩都超重,而且非常恶毒,总是让可怜的 Bruno 一无所有,所以他们的母亲决定分享食物的方式如下:
注:原问题描述不一样但是思路是一样的,不想让同学google求助的时候发现这个帖子呵呵。
我老师给出的一个测试用例如下:
The fruit list has the following values { 4, 2, 1, 8, 11, 5, 1}
Input:
7 -----> Number of Fruits
4 2 1 8 11 5 1 ----> Fruits Nutritional Values
Output:
1 11 ----> One fruit, their nutritional values sum for Amelia
5 ----> Position of the fruit in the list
3 11 ----> Three fruits, their nutritional values sum for Jessica
1 2 6 ----> Position of the fruits in the list
3 10 ----> Three fruits, their nutritional values sum for Bruno
3 4 7 ----> Position of the fruits in the list
注意:我知道有几种方法可以让 children 吃水果,但只要遵循规则 A >= J >= B 就没关系。
起初我做了一个生成所有子集的算法,每个子集都有它们的总和,以及正在使用的位置。那个方法很快就被废弃了,因为水果列表最多可以有50个水果,而且子集算法是O(2^n)。我的内存用完了。
我的第二个想法是使用动态规划。在列标题中我会有水果列表的位置,在行标题中也是如此,这有点难以用字母解释所以我会提前为前面的例子做表格 { 4, 2, 1, 8 , 11, 5, 1}.
00 01 02 03 04 05 06 07
00
01
02
03
04
05
06
07
每次我们前进到下一行时,我们都会添加位置 1,2,3,...,7
00 01 02 03 04 05 06 07
00 00 <---No positions in use
01 04 <---RowPosition 1 + Column Position(Column 0) (4+0)
02 06 <---RowPosition 1 + RowPosition 2 + Column Position (4+2+0)
03 07 <---RP(1) + RP(2) + RP(3) + CP(0) (4+2+1+0)
04 15 <--- (4+2+1+8+0)
05 26
06 31
07 32 <--- (4+2+1+8+11+5+1+0)
现在你知道它是怎么回事了,让我们添加第一行
00 01 02 03 04 05 06 07
00 00 04 02 01 08 11 05 01 <-- Sum of RP + CP
01 04 00 06 05 12 15 09 05 <-- Sum of RP(0..1) + CP
02 06
03 07
04 15
05 26
06 31
07 32
我输入 00 是因为第 1 个位置已被占用。完成的表格如下所示。
00 01 02 03 04 05 06 07
00 00 04 02 01 08 11 05 01
01 04 00 06 05 12 15 09 05
02 06 00 00 07 14 17 11 07
03 07 00 00 00 15 18 12 08
04 15 00 00 00 00 26 20 16
05 26 00 00 00 00 00 31 27
06 31 00 00 00 00 00 00 32
07 32 00 00 00 00 00 00 00
现在我们有了 table 。我将营养值(value)的总和除以 child 的数量,32/3 = 10.6667,上限为 11。我尝试检查 11,如果它在表中,我选择它并标记行的位置和使用的表的列,然后我会尝试再次检查 11,如果它在表中,我会选择它,否则查看 10 或 9 等,直到找到它。之后我会将各自的位置标记为已使用,然后将未使用的位置相加以获得布鲁诺的水果。
我知道必须有更好的方法来做到这一点,因为我发现我的方法有一个缺陷,该表只有几个子集的总和。所以也许这在一些测试用例中是有害的。也许是 3D Memoization Cube?,我认为它会消耗太多内存,而且我有 256MB 的限制。
哇,我没有意识到我输入了这么多 x.X。我希望我不会得到很多 tl;博士任何帮助/指南将不胜感激:D
编辑:我编写了生成表格的代码,以防有人想尝试一下。
static void TableGen(int[] Fruits)
{
int n = Fruits.Length + 1;
int[,] memo = new int[n, n];
for (int i = 1; i < n; i++)
{
memo[0, i] = Fruits[i - 1];
memo[i, 0] = memo[i - 1, 0] + Fruits[i - 1];
for (int j = i + 1; j < n; j++)
memo[i, j] = memo[i, 0] + Fruits[j - 1];
}
for (int i = 0; i < n; i++)
{
for (int j = 0; j < n; j++)
Console.Write("{0:00} ", memo[i, j]);
Console.WriteLine();
}
}
最佳答案
一种计算量稍大的方法是以循环方式分配水果,从阿米莉亚的最高营养值(value)开始。
从那里开始,从 amelia 持有的最低营养值(value)开始逐步循环水果,并尝试(a)将水果给 jessica 或(b)将水果与 jessica 持有的水果交换的每种组合,同时仍然满足规则。然后对杰西卡和布鲁诺应用同样的方法。重复这 2 个循环,直到没有更多的交换或给予是可能的。
稍微棘手但可能更快的是同时给予/交换给 jess/bruno。对于 A 持有的每 2 个水果,您将有 4 个选项可以尝试,如果您同时尝试平衡 J 和 B,则可以尝试更多选项。
要获得更快的算法,您可以尝试在数学堆栈交换站点上询问,因为这在很大程度上是一个集合论问题。
关于c# - 公平分享水果(动态规划),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11279710/
直接上代码,可以写在公共文件common和继承的基础类中,方便调用 ?
1、php服务端环境搭建 1.php 服务端环境 安装套件 xampp(apach+mysql+php解释器) f:\mydoc文件(重要)\dl_学习\download重要资源\apache
如下所示: Eclipse快捷键 Ctrl+1 快速修复 Ctrl+D: 删除当前行 Ctrl+Alt+↓ 复制当前行到下一行(复制增加) Ctrl+Alt+↑ 复制当前行到上一行(复制增加)
第一步:conn.PHP文件,用于连接数据库并定义接口格式,代码如下: php" id="highlighter_808731">
本篇文章整理了几道Linux下C语言的经典面试题,相信对大家更好的理解Linux下的C语言会有很大的帮助,欢迎大家探讨指正。 1、如果在Linux下使用GCC编译器执行下列程序,输出结果是什么?
安装完最新的Boost库 官方说明中有一句话: Finally, $ ./b2 install will leave Boost binaries in the lib/ subdirecto
为了梳理前面学习的《spring整合mybatis(maven+mysql)一》与《spring整合mybatis(maven+mysql)二》中的内容,准备做一个完整的示例完成一个简单的图书管理功
网站内容质量仅仅是页面综合得分里面的一项.不管算法如何改变调整,搜索引擎都不会丢弃网站页面的综合得分。 一般情况下我们把页面的综合得分为8个点: 1、标题的设置 (标题的设置要有独特性)
最近事情很忙,一个新项目赶着出来,但是很多功能都要重新做,一直在编写代码、debug。今天因为一个新程序要使用fragment来做,虽然以前也使用过fragment,不过没有仔细研究,今天顺道写篇文
Android资源命名规范 最近几个月,大量涉及android资源的相关工作。对于复杂的应用而言,资源命名的规范很有必要。除了开发人员之外,UI设计人员(或者切图相关人员)也需要对资源使用的位置非常
以前一直使用Hibernate,基本上没用过Mybatis,工作中需要做映射关系,简单的了解下Mybatis的映射。 两者相差不多都支持一对一,一对多,多对多,本章简单介绍一对一的使用以及注意点。
如下所示: ? 1
如果想在自定义的View上面显示Button 等View组件需要完成如下任务 1.在自定义View的类中覆盖父类的构造(注意是2个参数的) 复制代码 代码如下: publ
实现功能:实现表格tr拖动,并保存因为拖动改变的等级. jsp代码 ?
代码:测试类 java" id="highlighter_819000"> ?
红黑树是一种二叉平衡查找树,每个结点上有一个存储位来表示结点的颜色,可以是red或black。 红黑树具有以下性质: (1) 每个结点是红色或是黑色 (2) 根结点是黑色的 (3) 如果一个
废话不多说,直接上代码 ? 1
码代码时,有时候需要根据比较大小分别赋值: ? 1
实际项目开发中,我们经常会用一些版本控制器来托管自己的代码,今天就来总结下Git的相关用法,废话不多说,直接开写。 目的:通过Git管理github托管项目代码 1、下载安装Git 1、下载
直接上代码: 复制代码 代码如下: //验证码类 class ValidateCode { private $charset = 'abcdefghkmnprstuvwxyzABC
我是一名优秀的程序员,十分优秀!