传说中的poj必做50题之中的一个……

这是个传说中的搜索,

一開始以为,

仅仅要棒子加起来等于如果的原始长度,

那么这几根选择的棒子就不用管了,

结果卡在第一个例子……

看了一下,发现,

代码把1,2,1,2合成一个棒子,

这样其它就凑不成3根长度为6的棒子了,

写了半天,发现思路错了,

这个问题不知道怎样解决。

參考了下面地址的结题报告:

http://blog.csdn.net/lyy289065406/article/details/6647960

找到了一个解决的方法,

就是当合成了一个新的棒子的时候,

就又一次从第一个棒子開始枚举,

用没实用过的棒子,開始合成新的棒子。

写好代码之后,各种TLE……

于是又參考了上面那个解题报告,

找了个剪枝的办法,

就是假设碰到用某个棒子为第一个棒子合成新棒子

的时候,无法得到我想要的那种棒子,

就直接退栈并返回一个0表示这样不行,

写好之后,结果还是TLE,

于是继续剪了个枝

就是一開始给棒子递增排个序,

然后假设在合成棒子的中途发现

合成失败,用这根棒子得不到想要的那种棒子,

就把这个棒子标记一下,

假设在这次合成中再次碰到一样长度的棒子,

就直接舍弃。

又写好了……还是TLE。。。

我就不明确了……

再TLE,我真的没办法了。

又參考了结题报告,

发现给棒子递减排序就能够,

想了一下为毛,

是这种,由于优先增加长度较长的棒子,

更easy在比較少的次数里合成想要的那种棒子。

我的代码例如以下,欢迎讨论:

#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
int stick[74],num_stk,sum_len;
bool used[74];
bool cmp(int a,int b)
{
return a>b;
}
void init()
{
int i;
sum_len=0;
for(i=0;i<num_stk;i++)
{
scanf("%d",&stick[i]);
sum_len+=stick[i];
}
}
bool dfs(int s,int nlen,int nnum,int olen)
{
int i,x=-1;
if(nnum==num_stk)
return 1;
for(i=s;i<num_stk;i++)
{
if(used[i]||stick[i]==x||nlen+stick[i]>olen)
continue;
used[i]=1;
if(nlen+stick[i]<olen)
{
if(dfs(i+1,nlen+stick[i],nnum+1,olen))
return 1;
}
else
{
if(dfs(0,0,nnum+1,olen))
return 1;
}
x=stick[i];
used[i]=0;
if(nlen==0)
return 0;
}
return 0;
}
void work()
{
int i;
memset(used,0,sizeof(used));
sort(stick,stick+num_stk,cmp);
for(i=stick[0];i+i<=sum_len;i++)
{
if(sum_len%i==0&&dfs(0,0,0,i))
{
printf("%d\n",i);
return;
}
}
printf("%d\n",sum_len);
}
int main()
{
while(scanf("%d",&num_stk)&&num_stk!=0)
{
init();
work();
}
}

poj1011Sticks的更多相关文章

  1. 【深度搜索+剪枝】POJ1011-Sticks

    深搜部分和之前的POJ2362差不多,只是有几处需要额外的剪枝. [思路]排序后从最短木棒开始搜索至木棒长总和,如果木棒长总和sum能整除当前棒长,则进入深搜. [剪枝]先前POJ2362的剪枝部分不 ...

  2. DFS(7)——poj1011Sticks

    一.题目回顾 题目链接:Sticks 题意:给出一定数量的小木棒的长度,它是由等长的若干木棒随意砍断所得到的.对于给定的一组小木棒,请求出原始木棒的最小长度. 二.解题思路 DFS+剪枝 本题剪枝不到 ...

随机推荐

  1. 为什么希捷选择了8GB作为标准的闪存容量呢?答案就在下面(新的驱动器可以实现一定程度上的写入缓存)

    与前两代Momentus XT产品不同,希捷称第三代混合硬盘所使用的技术更接近真正的SSHD(Solid State Hybrid Disk?),而不是HHD.也就是说更偏向于固态硬盘.首先它不会属于 ...

  2. 基于visual Studio2013解决C语言竞赛题之0602最大值函数

     题目

  3. 一步一步重写 CodeIgniter 框架 (7) —— Controller执行时将 Model获得的数据传入View中,实现MVC

    1. 实现过程 1) 上一节讲述了 View 视图的加载过程,它是在 Loader 类中加载的,并通过 Include 语句进行包含.那么为了在 View 中传递变量,只需要在 include 语句所 ...

  4. python2.7 串口操作方式 编译 .py为windows可运行exe文件

    一 python操作串口 首先下载安装串口模块pyserial . 代码实现: import serial ser = serial.Serial('/dev/ttyUSB2', 115200) pr ...

  5. SQLyog 注册码

    用户名: 随意填写 秘钥: ccbfc13e-c31d-42ce-8939-3c7e63ed5417a56ea5da-f30b-4fb1-8a05-95f346a9b20ba0fe8645-3916- ...

  6. IOS_Note

    关键字:可以搜索这些关键字找到具体内容 退回输入键盘.CGRect.CGPoint & CGSize.设置透明度.设置背景色.自定义颜色. 竖屏.横屏.状态栏高  (显示时间和网络状态). 导 ...

  7. 修改 Mac 默认 PHP 运行环境,给 MAMP 配置全局 Composer

    在没有配置全局性的 Composer 的时候,如果你在没有安装 Composer 的目录下运行 Composer 命令,比如:create-project 系统会返回: Could not open ...

  8. Windows的TCP协议参数

    注册表编辑器:regedit 表项:HKEY_LOCAL_MACHINE\SYSTEM\CurentControlSet\Services\Tcpip\Parameters 窗口扩大因子 & ...

  9. Goodle Clean设计架构

    Goodle Clean设计架构 23 * @param <P> the response type 24 */ 25 public abstract class UseCase<Q ...

  10. 普通图片转ascii码字符图

    效果图 基本思路 把图片每个像素点的信息拿出来,最重要的是拿到rgb的值 把每个像素点由rgb转成灰度图像,即0-255 给0-255分级,把每个等级的像素点转换成ascii码,完成 实现 第一步:获 ...