题目链接:https://vjudge.net/problem/POJ-1011

题意:给定n(<=64)条木棍的长度(<=50),将这些木棍刚好拼成长度一样的若干条木棍,求拼出的可能的最小长度。

思路:经典的DFS剪枝题,这道题的剪枝技巧很关键。

  数据不大,可以想到枚举木棍所有可能的长度,然后利用dfs来查找所有可能的搭配情况,dfs的参数len表示当前的木棍长度,rest表示还需要的长度,pos表示当前搜到的下标,num表示原始木棍中剩余没有匹配的数量,搜索的终止条件为rest==0&&num==0,但直接这样做还是会超时,这道题有许多的剪枝技巧:

  1. 将序列降序排序,方便后面的剪枝。

  2. 枚举的范围是[Max,sum/2],其中Max为序列中的最大值,sum为序列和。

  3. 可能的长度只能是sum的约数。

  4. 深搜时,如果在寻找一条新木棍时使用了剩余木棍中最长的也不能满足条件,则直接返回。因为最长的一根一定要使用,不用的话后面也一直用不到,最终是无法成功匹配的。对应代码中的if(!rest)中的语句。

  5. 深搜时,如果当前木棍刚好使正在凑的木棍形成新木棍,但也不满足条件时,直接返回。比如你现在是3,使用3刚好能凑出一根新木棍,但使用之后后面仍无法满足条件,现在即使后面存在1 2,你使用1 2来凑出剩下的3也一定不能满足条件,因为1 2两条木棍比3更灵活,使用1 2都无法成功的话使用3更无法成功。对应代码if(a[i]==rest) break。

  6. 当前木棍长为x,使用x无法满足条件时,则可直接跳过后面所有长为x的木棍。对应代码while(a[i+1]==a[i]) ++i。

AC代码:

#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std; int n,a[],vis[],ans; bool cmp(int x,int y){
return x>y;
} bool dfs(int len,int rest,int pos,int num){
if(!rest&&!num){
ans=len;
return true;
}
if(!rest){
rest=len;
for(int i=;i<n;++i){
if(vis[i]) continue;
vis[i]=;
if(dfs(len,rest-a[i],i+,num-))
return true;
vis[i]=;
return false;
}
}
for(int i=pos;i<n;++i){
if(vis[i]) continue;
if(a[i]<=rest){
vis[i]=;
if(dfs(len,rest-a[i],i+,num-))
return true;
vis[i]=;
if(a[i]==rest) break;
while(a[i+]==a[i]) ++i;
}
}
return false;
} int main(){
while(scanf("%d",&n),n){
int sum=,flag=;
for(int i=;i<n;++i){
scanf("%d",&a[i]);
sum+=a[i];
}
sort(a,a+n,cmp);
memset(vis,,sizeof(vis));
for(int i=a[];i<=sum/;++i){
if(sum%i==){
if(dfs(i,i,,n)){
flag=;
break;
}
}
}
if(flag)
printf("%d\n",ans);
else
printf("%d\n",sum);
}
return ;
}

  

poj1011(DFS+剪枝)的更多相关文章

  1. *HDU1455 DFS剪枝

    Sticks Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Subm ...

  2. POJ 3009 DFS+剪枝

    POJ3009 DFS+剪枝 原题: Curling 2.0 Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 16280 Acce ...

  3. poj 1724:ROADS(DFS + 剪枝)

    ROADS Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 10777   Accepted: 3961 Descriptio ...

  4. DFS(剪枝) POJ 1011 Sticks

    题目传送门 /* 题意:若干小木棍,是由多条相同长度的长木棍分割而成,问最小的原来长木棍的长度: DFS剪枝:剪枝搜索的好题!TLE好几次,终于剪枝完全! 剪枝主要在4和5:4 相同长度的木棍不再搜索 ...

  5. DFS+剪枝 HDOJ 5323 Solve this interesting problem

    题目传送门 /* 题意:告诉一个区间[L,R],问根节点的n是多少 DFS+剪枝:父亲节点有四种情况:[l, r + len],[l, r + len - 1],[l - len, r],[l - l ...

  6. HDU 5952 Counting Cliques 【DFS+剪枝】 (2016ACM/ICPC亚洲区沈阳站)

    Counting Cliques Time Limit: 8000/4000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) ...

  7. HDU 5937 Equation 【DFS+剪枝】 (2016年中国大学生程序设计竞赛(杭州))

    Equation Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total S ...

  8. LA 6476 Outpost Navigation (DFS+剪枝)

    题目链接 Solution DFS+剪枝 对于一个走过点k,如果有必要再走一次,那么一定是走过k后在k点的最大弹药数增加了.否则一定没有必要再走. 记录经过每个点的最大弹药数,对dfs进行剪枝. #i ...

  9. poj 1011 Sticks (DFS+剪枝)

    Sticks Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 127771   Accepted: 29926 Descrip ...

随机推荐

  1. vuex , 简单入(liao)门(jie)

    vuex什么 ? 官方的说法就是 vuex是专门为vue.js应用程序开发的 状态管理模式 .并采用集中式存储 , 管理应用的所有组件的状态 ,并以相同的规则保证状态以一种可预估的方式发生变化. 自己 ...

  2. vue启动问题(You may use special comments to disable some warnings. Use // eslint-disable-next-line to ignore the next line. Use /* eslint-disable */ to ignore all warnings in a file.)

    解决vue启动出现: 在build/webpack.base.conf.js文件中,把...(config.dev.useEslint ? [createLintingRule()] : [])注释或 ...

  3. 对JS继承的研究--------------引用

    问:类继承和原型继承不是同一回事儿吗,只是风格选择而已? 答:不是! 类继承和原型继承不论从本质上还是从语法上来说,都是两个截然不同的概念. 二者之间有着区分彼此的本质性特征.要完全看懂本文,你必须牢 ...

  4. ping —— 虚拟机

    1. 主机ping 虚拟机 ping 不通    设置——虚拟机—— 防护墙——入站规则——  文件和打印共享 (回显请求-ICMPv4-In) 2.主机连接不上虚拟机中的sqlsrver   设置— ...

  5. Libraries&Workflow for a modern geospatial processing(现代地理空间处理的库与工作流)

    Libraries for a modern geospatial workflow现代地理空间工作的类库 Distribution Writing, Running, and Distributin ...

  6. 论文阅读:Offloading Distributed Applications onto SmartNICs using iPipe

    摘要: 包含丰富计算资源的新兴多核SoC SmartNIC具有卸载通用数据中心服务器任务的潜力,但是目前尚不清楚如何有效地使用SmartNIC并最大程度地减少卸载收益,尤其是对于分布式应用程序. 为此 ...

  7. Apicloud_(模板)登陆注册功能模板

    项目已托管到Github上 传送门 不需要使用任何图片资源,需要用到SHA1.js库文件, Apicloud_(接口验证)用户注册头部信息X-APICloud-AppKey生成 传送门 项目全代码放到 ...

  8. sqli-labs(40)

    0X01同样是构造闭合 这里的闭合条件是') 构造语句 ?id=');insert into users values(100,'tx','tx')%23 在客户端mysql里面看看 嘿嘿 成功执行 ...

  9. 品 SpringBootApplication 注解源码

    @SpringBootApplication 由以下三个注解构成: @SpringBootConfiguration@EnableAutoConfiguration@ComponentScan 一:@ ...

  10. Java常考面试题整理(三)

    明天又要去面试,Good luck to me.,让我在这段时间换个新的工作吧. 41.在Java中,对象什么时候可以被垃圾回收? 参考答案: 当对象对当前使用这个对象的应用程序变得不可触及的时候,这 ...