二进制优化,事实上是物体的分解问题。

就是比方一个物体有数量限制,比方是13,那么就须要把这个物体分解为1。 2, 4, 6

假设这个物体有数量为25,那么就分解为1, 2, 4。 8。 10

看出规律吗,就是分成2的倍数加上位数,比方6 = 13 - 1 - 2 - 4, 10 = 25 - 1 - 2 - 4 - 8。呵呵,为什么这么分解?

由于这样分解之后就能够组合成全部1到13的数。为25的时候能够组合成全部1到25的数啦。

就是这么一个分解物体。最后组合的问题。

不明确?

给多几个数字组合:

31分解 1, 2, 4, 8, 16

32分解1,2,4, 8, 16, 1

33分解1,2,4,8,16,2

如此分解的。

想通了,就和一般背包问题一样做法了。

#include <stdio.h>
#include <vector>
using std::vector; const int SIZE = 7;
int N[SIZE];
bool findPartition()
{
int sum = 0;
for (int i = 1; i < SIZE; i++)
sum += i * N[i];
if (sum & 1) return false; int half = sum >> 1;
vector<bool> part(half+1);
part[0] = true; for (int i = 1; i < SIZE; i++)
{
int k = 1;
for ( ; (k<<1) <= N[i]; k <<= 1)
{//例:13分解为1,2,4,6能够组合为1到13个物品。故此考虑了全部情况了
for (int j = half; j >= k*i; j--)
{
if (part[j-k*i]) part[j] = true;
}
}
k = N[i] - k + 1;
for (int j = half; j >= k*i; j--)
{
if (part[j-k*i]) part[j] = true;
}
}
return part[half];
} int main()
{
int t = 1;
while (true)
{
int val = 0;
for (int i = 1; i < SIZE; i++)
{
scanf("%d", &N[i]);
val += N[i];
}
if (!val) return 0;
if (findPartition()) printf("Collection #%d:\nCan be divided.\n\n", t++);
else printf("Collection #%d:\nCan't be divided.\n\n", t++);
}
return 0;
}

最新文章

  1. 【Win 10 应用开发】获取本机的IP地址
  2. SqlException 当前命令发生了严重错误 应放弃任何可能产生的结果
  3. Spting--DI/IOC
  4. 修改远程桌面连接端口3389,RDP-Tcp的portnumber要用十六进制修改
  5. mysql C API的使用
  6. word20161201
  7. libbspatch.so
  8. Cow Exhibition_背包(负数情况)
  9. Entity Framework学习笔记(四)----Linq查询(1)
  10. jQuery日历和日期选取插件
  11. css:nth-of-type()选择器用法
  12. java问题:类的定义,对象的定义?
  13. E​F​I​主​板​和​G​P​T​分​区​表​安​装​系​统以及转换GPT分区表的方法
  14. Web UI 网站用户界面设计命名规范
  15. [Android App]IFCTT,即:If Copy Then That,是一个基于IFTTT的&quot;This&quot;实现
  16. python使用sqlmap API检测SQL注入
  17. JDK8 BigDecimal API-创建BigDecimal源码浅析三
  18. Fiddler 断点功能
  19. 19. vue的原理
  20. Python全栈开发记录_第一篇(循环练习及杂碎的知识点)

热门文章

  1. Android开发之EditText 详解(addTextChangedListener监听用户输入状态)
  2. Dictionaries
  3. POJ 3280 DP
  4. java9新特性-3-JDK 和 JRE 的改变
  5. Android属性动画-基本用法
  6. java必会的英语单词
  7. SQL--CLR概述
  8. ArchLinux dwm的安装和配置
  9. 如何创建一个可以使用try.....catch.......捕获的异常
  10. C# http服务器