社区讨论
玄关求条
P10527 [XJTUPC 2024] 最后一块石头的重量参与者 1已保存回复 0
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 0 条
- 当前快照
- 1 份
- 快照标识符
- @mhjs6bgd
- 此快照首次捕获于
- 2025/11/04 07:38 4 个月前
- 此快照最后确认于
- 2025/11/04 07:38 4 个月前
老师的代码,超时了。。。
CPP#include<bits/stdc++.h>
using namespace std;
/**
* 非负数组nums中,子序列累加和不超过t,但是最接近t的累加和是多少
* 01背包问题(子集累加和尽量接近t) + 空间压缩
*/
int solve(vector<int> &nums, int target) {
vector<int> dp(target + 1, 0);
for (int num: nums) {//for(int num=0;num<nums.size();num++)
for (int j = target; j >= num; j--) {
// dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - nums[i]] + nums[i])
dp[j] = max(dp[j], dp[j - num] + num);
}
}
return dp[target];
}
int lastStoneWeightII(vector<int> &nums) {
int sum = 0;
for (int num: nums) {
sum += num;
}
/**
* nums中随意选择数字
* 累加和一定要 <= sum / 2
* 又尽量接近
*/
int nearSum = solve(nums, sum / 2);
return (sum - nearSum) - nearSum;
}
int main() {
int n;
cin >> n;
vector<int> nums(n);
for (int i = 0; i < n; i++) {
// cin >> nums[i];
scanf("%d",&nums[i]);
}
int result = lastStoneWeightII(nums);
cout << result << endl;
return 0;
}
回复
共 0 条回复,欢迎继续交流。
正在加载回复...