社区讨论

玄关求条

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 条回复,欢迎继续交流。

正在加载回复...