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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

将一个数组划分为和差值最小的子数组

發(fā)布時間:2025/7/14 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 将一个数组划分为和差值最小的子数组 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

要求:將數(shù)組中的數(shù)劃分為兩組,使得兩個子數(shù)組的和的差值最小,數(shù)組中的數(shù)的取值范圍為0<X<100,元素個數(shù)也是大于0小于100.如:a[]={2,4,5,6,7},得出的兩組數(shù):{2,4,6}和{5,7},abs(sum(a1)-sum(a1))=0;如:{2,5,6,10},abs(sum(2,10)-sum(5,6))=1所以:子數(shù)組為:{2,10}和{5,6}。

思路:很容易知道如果選取的某個子數(shù)組的和currentSum=sum/2,則這兩個子數(shù)組的和的差值最小,即從數(shù)組中選取某些數(shù)字使得其和接近整個數(shù)組的1/2.,所以該命題本質(zhì)上是一個01背包命題,原命題等價于從n各物品中選取若干個,其重量不超過sum/2,且重量達(dá)到最大
基于上述思路代碼如下:
#include <iostream> using namespace std;const int M = 100; int w[M]; int currentSum[M*M]; bool state[M][M]; int main() {int n;while (scanf("%d ", &n) != EOF) {//輸入數(shù)組元素個數(shù)int sum = 0;for (int i = 0; i < n; ++i) {scanf("%d", &w[i]);sum += w[i];//sum存儲整個數(shù)組元素的和}memset(currentSum, 0, sizeof(currentSum));memset(state, 0, sizeof(state));for (int i = 0; i < n; ++i)for (int j = sum/2; j >= w[i]; --j) {if (currentSum[j] < currentSum[j-w[i]] + w[i]) {currentSum[j] =currentSum[j-w[i]] + w[i];state[i][j] = true;}}printf("%d\n", sum - currentSum[sum/2]*2);int i = n, j = sum/2;while (i--) {if (state[i][j]) {printf("%d ", w[i]);j -= w[i];}}printf("\n");}return 0; }程序運行結(jié)果如下:

轉(zhuǎn)載于:https://www.cnblogs.com/hainange/p/6334064.html

總結(jié)

以上是生活随笔為你收集整理的将一个数组划分为和差值最小的子数组的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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