划分问题(dp)
来源:互联网 发布:高中数学最优化问题 编辑:程序博客网 时间:2024/06/05 13:21
给出一个整数集合 , 将这个集合分成2个 和相等的集合。
思路就是 总和的一半作为一个目标容量,在集合中寻找是否可以有元素的和恰好为这个目标容量,也就转化为一个类似01背包问题。
这篇文章讲的比较详细
http://www.acmerblog.com/partition-problem-5801.html
#include <iostream>#include <algorithm>#include <stdio.h>using namespace std;int a[105];bool dp[105][50005];int main(){ int n; while ( ~scanf("%d",&n) ) { int sum=0; for(int i=0;i<n;i++) { cin >> a[i]; sum+=a[i]; } if(sum%2 != 0) { cout << "NO" << endl ; continue; } int v=sum/2; for(int i=0;i<=n;i++) dp[i][0]=true; for(int i=0;i<=v;i++) dp[0][i]=false; for(int j=1;j<=v;j++) for(int i=1;i<=n;i++) { dp[i][j]=dp[i-1][j]; if( j >= a[i-1] ) dp[i][j] = dp[i][j] || dp[i-1][j-a[i-1]]; } if( dp[n][v] ) cout << "YES" << endl; else cout << "NO" << endl; } return 0;}
0 0
- 划分问题(dp)
- DP--划分问题(1)
- nyoj 571 整数划分问题(dp)
- dp-整数划分问题(理论分析)
- dp-整数划分问题(理论分析)
- DP--划分问题(掷骰子)
- 复杂的整数划分问题(dp)
- 题解:整数划分问题(DP)
- 划分数问题 DP
- 整数划分问题 【DP】
- 整数划分问题 DP
- dp-整数划分问题
- 一类DP问题的分析(划分DP)
- 数的划分问题 【DP】
- 划分数(DP)
- 校OJ 8597 石子划分问题(dp)
- 百练:简单的整数划分问题(经典dp)
- 经典问题四. (区间dp) 凸多边形最优三角形划分
- leetcode Recover Binary Search Tree
- 路径定向错误
- c++模板类(一)理解编译器的编译模板过程
- NS2的UDP模拟
- 符号对象(Symbolic Object)的使用
- 划分问题(dp)
- ADO初始化接口时出现“不支持此接口”错误
- javascript对象
- java四则运算
- This project is incompatible with the current version of Visual Studio
- android中init.rc文件的解析问题
- LINUX DNS 配置
- 关于shop++物流查询功能分享
- Loner_li 机试题 将数字 例如"12345.7895”,用程序实现显示"壹万贰仟叁佰肆拾伍圆柒角玖分"的方式