社区讨论

再剪枝,我给你树干子都剪了!!!

P1120[CERC 1995] 小木棍参与者 6已保存回复 17

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
17 条
当前快照
1 份
快照标识符
@mi1vburb
此快照首次捕获于
2025/11/16 23:26
3 个月前
此快照最后确认于
2026/02/11 02:43
上周
查看原帖
CPP
#include<bits/stdc++.h>
using namespace std;
int n,total,ma;
vector<int> stick;
vector<bool> used;
bool dfs(int current,int count,int start,int target){
	if(count*target==total) return 1;
	if(current==target) return dfs(0,count+1,0,target);
	int	fail=0;
	for(int i=start;i<n;i++){
		if(!used[i] && current+stick[i]<=target && stick[i]!=fail){
			used[i]=1;
			if(dfs(current+stick[i],count,i+1,target)){
				return 1;
			}
			used[i]=0;
			fail=stick[i];
			if(current==0 || current+stick[i]==target){
				return 0;
			}
		}
	}
	return 0;
}
int main(){
	scanf("%d",&n);
	stick.resize(n);
	used.resize(n,0);
	for(int i=0;i<n;i++){
		scanf("%d",&stick[i]);
		total+=stick[i];
		ma=max(ma,stick[i]);
	}
	sort(stick.begin(),stick.end(),greater<int>());
	for(int i=ma;i<=total/2;i++){
		if(total%i==0){
			fill(used.begin(),used.end(),0);
			if(dfs(0,0,0,i)){
				printf("%d",i);
				return 0;
			}
		}
	}
	printf("%d",total);
    return 0;
}

以上是我一个清纯、可爱、无知的青少年能想出来的全部的剪枝了!!!
各个大佬快来帮帮我这个清纯、可爱、无知的青少年吧。

回复

17 条回复,欢迎继续交流。

正在加载回复...