日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

POJ 1014 Dividing 背包

發(fā)布時間:2025/3/8 编程问答 15 豆豆
生活随笔 收集整理的這篇文章主要介紹了 POJ 1014 Dividing 背包 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

二進制優(yōu)化,事實上是物體的分解問題。

就是比方一個物體有數(shù)量限制,比方是13,那么就須要把這個物體分解為1。 2, 4, 6

假設(shè)這個物體有數(shù)量為25,那么就分解為1, 2, 4。 8。 10

看出規(guī)律嗎,就是分成2的倍數(shù)加上位數(shù),比方6 = 13 - 1 - 2 - 4, 10 = 25 - 1 - 2 - 4 - 8。呵呵,為什么這么分解?

由于這樣分解之后就能夠組合成全部1到13的數(shù)。為25的時候能夠組合成全部1到25的數(shù)啦。

就是這么一個分解物體。最后組合的問題。

不明確?

給多幾個數(shù)字組合:

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; }


總結(jié)

以上是生活随笔為你收集整理的POJ 1014 Dividing 背包的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。