题意:给定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;
}

最新文章

  1. Java面试题总结 from Baidu 网易 阿里
  2. servlet的九大内置对象
  3. Java中将unix时间戳转化为正常显示时间
  4. Odyssey.js – 创建互动的,有吸引力的故事
  5. ubuntu的dns设置
  6. 虚拟化之kvm与xen对比
  7. Qt之软件打包
  8. 【Latex】如何在Latex中插入伪代码 —— clrscode3e
  9. 精通 Oracle+Python,第 1 部分:查询最佳应践
  10. string 转换char类型
  11. greenDAO简介
  12. python中xrange用法分析
  13. 测试String.Format中的Format参数
  14. KS检验统计量的扩展应用(CMap)
  15. monkey日志解析
  16. hashCode和equals的关系分析
  17. Home School Books美国家庭学校教育小学初中高中全套美语教材
  18. redis分布式锁(转)
  19. JDBC:随机生成车牌号,批量插入数据库
  20. vm centos7中用NAT模式配置上网

热门文章

  1. 383. Ransom Note 在字典数组中查找笔记数组
  2. npm link和react native的问题
  3. 使用Cytoscape画PPI网络图
  4. Django框架 之 基于Ajax中csrf跨站请求伪造
  5. Windows7下使用sphinx生成开源文档(原)
  6. Hacker News排名算法工作原理
  7. 一张图看懂ASP.NET MVC5认证和授权过滤器的执行顺序
  8. Spring Websocket与sockJS结合实现
  9. Server Sql 多表查询、子查询和分页
  10. switch case 判断是否为按钮、设置属性 Load Foreach 绑定事件