POJ - 1011 剪枝练习
2024-08-28 18:56:38
题意:给定n条拆掉的棍子,问能凑成最短的多条相同长度棍子的最短长度
x:当前第几条正在合成的棍子
y:目前正在尝试的拆掉的棍子
z:当前长度
剪枝方案:
1.按照长度单调性排序,减少重复搜索
2.如果当前拼接棍子失败,那接下来相同长度也会失败
3.第一条棍子就失败就不必搜索了
/*H E A D*/
int a[666],tot,ans,sum,n;
bool used[666];
bool dfs(int x,int y,int z){
if(x==tot+1) return 1;
if(z==sum/tot) return dfs(x+1,1,0);
if(y==n+1) return 0;
int failed=0;//!!!
rep(i,y,n){
if(!used[i]&&z+a[i]<=sum/tot&&failed!=a[i]){
used[i]=1;
if(dfs(x,y+1,z+a[i])) return 1;
failed=a[i];
used[i]=0;
if(z==0)return 0;//!!!
}
}
return 0;
}
int main(){
while(~iin(n)){
if(n==0)break;
rep(i,1,n) a[i]=read();
sort(a+1,a+1+n,greater<int>());
sum=0;
rep(i,1,n) sum+=a[i];
ll ans=oo;
rrep(i,sum,1){
if(sum%i==0){
tot=i;
memset(used,0,sizeof used);
if(dfs(1,1,0)){
ans=min(ans,(ll)sum/tot);
break;
}
}
}
println(ans);
}
return 0;
}
int main(){
while(~iin(n)){
if(n==0)break;
rep(i,1,n) a[i]=read();
sort(a+1,a+1+n,greater<int>());
sum=0;
rep(i,1,n) sum+=a[i];
ll ans=oo;
rrep(i,sum,1){
if(sum%i==0){
tot=i;
flag=0;
memset(used,0,sizeof used);
if(dfs(1,1,0)){
ans=min(ans,(ll)sum/tot);
break;
}
}
}
println(ans);
}
return 0;
}
最新文章
- Java面试题总结 from Baidu 网易 阿里
- servlet的九大内置对象
- Java中将unix时间戳转化为正常显示时间
- Odyssey.js – 创建互动的,有吸引力的故事
- ubuntu的dns设置
- 虚拟化之kvm与xen对比
- Qt之软件打包
- 【Latex】如何在Latex中插入伪代码 —— clrscode3e
- 精通 Oracle+Python,第 1 部分:查询最佳应践
- string 转换char类型
- greenDAO简介
- python中xrange用法分析
- 测试String.Format中的Format参数
- KS检验统计量的扩展应用(CMap)
- monkey日志解析
- hashCode和equals的关系分析
- Home School Books美国家庭学校教育小学初中高中全套美语教材
- redis分布式锁(转)
- JDBC:随机生成车牌号,批量插入数据库
- vm centos7中用NAT模式配置上网