- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
Min-Coin Change 问题已得到充分研究(可以在此处找到解释:http://www.algorithmist.com/index.php/Min-Coin_Change),但我有兴趣解决它的变体:
For a set of values V, determine a minimal set of coins C such that each of the values in V can be obtained as a sum of coins in C, where each coin in the set may only be used at most once. By minimal we mean the least number of coins.
例如,如果 V = {3, 8, 9, 10, 11} 那么很容易看出 C = {1, 2, 8} 因为 1 + 2 = 3, 8 = 8, 9 = 1 + 8、10 = 2 + 8 和 11 = 1 + 2 + 8。没有更小的集合 C' 也涵盖所有这些数额。
到目前为止,我想不出比暴力破解子集更好的工作方法,这显然不适用于大型 V。我正在寻找可以向我展示更好的解决方案或为我指明相关方向的人问题。
编辑:请注意,可能有多个最小集合,我只想找到其中一个。
最佳答案
只是一个非常部分的解决方案/评论:
如果你的集合 V 的大小为 N,那么你在 C 中至少需要 ceil[log_2(N)] 个元素。事实上,你可以用一组 m 个元素生成的值的数量最多为 2^m 等等你必须有 2^|C| >= N.
如果 V 中至少但不是所有数字中设置为 1 的总位数(在数字的二进制表示中)等于 n,则 C 中最多需要 n 个元素。此外,你通过让 C = {2^{x_1}*r, .., 2^{x_n}*r} 得到这个大小的集合 C 其中 x_i 是至少在一个但不是所有元素中设置为 1 的位V,r由V的所有元素中设置为1的位组成。
在您的情况下,您可以观察到两个边界匹配,因此上面第二段构造的集合 C(实际上等于您建议的集合)是您问题的解决方案。
编辑
基于以上,下面的构造呢:
设n为V的二进制表示最大元素的位数。
令 S = {1, .., n}。令 T 为在 V 的所有元素中设置为零的位集。令 S_0 为在 V 的所有元素中设置为 1 的位集。设 x_1 为 S\setminus (T\cup S_0) 的第一个元素。令 S_1 由 V 的所有元素中与 x_1 取相同值的所有位组成。设 x_2 为 S\setminus (T\cup S_0\cup S_1) 的第一个元素。令 S_2 由 V 的所有元素中与 x_2 取相同值的所有位组成。让 x_3 .... 依此类推,直到 S = (T\cup S_0\cup S_1\cup S_r)。
然后通过考虑由定义的数字 x_0,x_1, .., x_r 获得 Cx_i = sum_{j\cup S_i} 2^j
我相当确信这会产生最佳集合 C(尽管我还没有证据)。
例如,在您的示例中,您将以二进制表示形式编写 3 = 0011 8 = 1000 9 = 1001 10 = 1010 11 = 1011
所以 T_0 = {3},S_0 = {},S_1 = {1},S_2 = {2},S_3 = {4}。
关于algorithm - Min-Coin Change 变化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30509943/
编辑:为了澄清,我想问的是:在什么情况下您会更喜欢一种语法而不是另一种语法? 有什么区别: .trigger('change') 和 .change() 两者都按预期工作。在任何情况下语法都会有所不同
这个问题在这里已经有了答案: Difference between .on('click') vs .click() (12 个答案) 关闭 6 年前。 有什么区别: $('选择器').change
我用的是Select2-4.0.0 和 $gameSelect.select2().on("change",function(e){....} 工作正常。 但是当我将它链接起来时('change')就
有一天在#haskell 上,有人提到了当字符串改变时字符串的类型应该如何改变的概念。这让我想起了我项目中的一些代码。它一直困扰着我,我说不清为什么。我现在推测,原因是我没有实现这个概念。这是下面的代
我使用了 .on("change") 事件函数,因为我的整个代码中有一部分是动态变化的。 .trigger("change") 在 .change() 中工作正常,但在 .on("change") 中
下面是一个非常简单的表单下拉列表设置。但是,on-change 事件拒绝触发...除非它更改为 ng-change。 这让我卡住了大约一个小时,因为我们在网站的其他地方使用了相同的设置(即模型属性/列
我有两个v-model 案例一: 这很好用 案例二: 即使改变 u1 也会触发 onDateChange(); 最佳答案 :change 绑定(bind)属性,如 v-bind:change=
我找到了 .and方法对于链接许多期望非常有用。 expect { click_button 'Update Boilerplate' @boilerplate_original.reload
出于合规性原因,我需要捕获所有数据库更改。我知道 Change Feed 存储此信息(并且我正在等待完全保真度来捕获删除)。目前,我一直在通过 Function 触发器读取 Change Feed 并
我添加了一个data-ng-change='getSubjectsClasswise(classBean.class_id);'上课标签,但主题未在主题 处加载标签。 一切看起来都很好,没有遇到问题
我有一组复选框,当您单击其中一个时,它们应该全部被选中。 当用户单击一个复选框时,它会检查以该类名称开头的所有其他复选框。我想要的是用户单击一个复选框,并且每次单击仅触发一次 $(".atpSelec
我在 Stack Overflow 上阅读了很多有关此问题的内容,并应用了所有建议的解决方案(getShell pack、布局、getparent 布局等...),但没有一个起作用。 我有一个带有文本
我想更改我的索引。我的数据框如下: partA = pd.DataFrame({'u1': 2, 'u2': 3, 'u3':4, 'u4':29, 'u5':4, 'u6':1, 'u7':323,
我有一个像这样的下拉菜单: Grade Year 旁边还有另一个下拉菜单: 3 4
这个问题已经有人问过,但我只停留在最基本的层面上。除了选择标记和尝试通过 jquery 捕获更改事件外,我没有向我的 html 添加任何内容。这是我的代码: $('#target').bin
我只是 Django 的新手几天。现在,当自定义表单中其他字段的值发生变化时,我需要同时更改一个字段中的值和表示形式。此时更改 MyModel 是受限。 我的应用程序/models.py: class
我正在使用 ListView 控件来显示一些数据行。有一个后台任务接收列表内容的外部更新。新收到的数据可能包含更少、更多或相同数量的项目,而且项目本身可能已更改。 ListView.ItemsSour
我在 android studio 中使用 git 插件。我的问题是当我提交更改列表(公开提交)时,但我在更改列表中的评论是错误的/丢失的,我想更改它。 问题: 有没有办法通过 AndroidStud
MyCustomObject * object=new MyCustomObject(); 假设我的许多类都使用了对象指针,但突然间我想在不更改地址的情况下更改指针的内容。 我认为 object =
我正在使用新的 KeyValue Observing。当变量发生变化时,我接到了我的观察者的电话,但 change struct 附带 newValue和 oldValue都为 nil ,所以它永远不
我是一名优秀的程序员,十分优秀!