点击打开链接

题目大意是有一个分割机,可以把一串数字分割成若干个数字之后求和,题目输入一个数字上界和待分割的数字,让我们求出分割后数字之和在不超过给定max的情况下的最大值,并且给出分割方案,如果没有分割方案,则输出error,如果有多种方案则输出rejected。

这是个搜索题,深搜就可以求解,但是有一些剪枝的方案,题目讨论区说貌似不剪枝也能过,没试过,我一开始就写了有剪枝的,下面说一下一些剪枝方案:

假设题目输入格式为max number

1,如果number各个位相加以后仍然大于max,则error,这是在搜索之前判断的

2,如果number  <= max 那么number就是切割方案,因为number能切出来的最大数是它本身,最小数就是各位之和了

3.,搜索过程中动态改变下界,如果我们之前搜索过的结果中有一个结果ans出现了,那么当我们搜索时,我们首先判断前面所有裁剪的总和sum和剩下的那一段x的和,如果小于之前求出的ans,那么后面将不再拆分 x 因为再怎么拆分也不会得到更接近max的ans了,相反,如果sum + x大于ans并且小于max,那么直接把ans更新为sum + x,也不用继续裁剪x了,因为x裁剪出来的也必定小于x,所以这个剪枝个人感觉还是比较强力的,只有sum + x  > max的时候才能往下搜索,需要注意的是104会分成1
0 4和1 04,同样也会有140分解成1 4 0的问题,所以我用了两个标记来区分这两种情况,所以写的比较绕

0MS代码:

#include<stdio.h>
int stack[20];
int max;
int top;
int len;
bool f;
int ans[20];
void dfs(int it, char * num, int sum, int n)
{
if(!num[it])
return ;
int i;
int numb = 0;
for(i = it; num[i]; i++)
{
int j;
bool mark = false;
numb = 0;
int number;
for(j = it; j <= i; j++)
{
numb *= 10;
numb += num[j] - '0';
}
if(num[i + 1] == '0' && num[i + 2] != 0)
mark = true;
if(num[i + 1] != 0)
sscanf(num + i + 1, "%d", &number);
else
number = 0;
if(number + numb + sum < max)
continue;
else if(number + numb + sum == max)
f = true;
else if(number + numb + sum > max && number + numb + sum <= n)
{
max = number + numb + sum;
if(mark == true)
f = true;
else
f = false;
stack[top ++] = numb;
stack[top ++] = number;
for(j = 0; j < top; j++)
ans[j] = stack[j];
len = top;
top -= 2;
continue;
}
stack[top++] = numb;
dfs(i + 1, num, sum + numb, n);
top --;
}
}
int main()
{
int n, m;
char num[20];
while(scanf("%d %d", &n, &m), n + m != 0)
{
if(m <= n)
{
printf("%d %d\n", m, m);
continue;
}
sprintf(num, "%d", m);
int i;
int sum = 0;
for(i = 0; num[i]; i++)
{
sum += num[i] - '0';
}
if(sum > n)
{
printf("error\n");
continue;
}
top = len = 0;
max = -1;
f = false;
dfs(0, num,0, n);
if(f == false)
{
printf("%d", max);
for(i = 0; i < len; i++)
printf(" %d", ans[i]);
printf("\n");
}
else
printf("rejected\n");
}
return 0;
}

poj 1416 (hdu 1539)Shredding Company:剪枝搜索的更多相关文章

  1. POJ 1416 Shredding Company 回溯搜索 DFS

    Shredding Company Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 6173   Accepted: 3361 ...

  2. HDU 2437 Jerboas (剪枝搜索)

    题意:给定一幅图,图上有两种点T,P.......一只跳鼠在一个T点作为起始点,它想通过图上的路到达某个P点,P点满足如下要求: (1).到达P点的途中路径权值为k的倍数 (2).尽量让路径权值取最小 ...

  3. 【HDOJ】1539 Shredding Company

    DFS. /* 1539 */ #include <iostream> #include <cstdio> #include <cstring> #include ...

  4. POJ 1198 / HDU 1401 Solitaire (记忆化搜索+meet in middle)

    题目大意:给你一个8*8的棋盘,上面有四个棋子,给你一个初始排布,一个目标排布,每次移动,可以把一个棋子移动到一个相邻的空位,或者跨过1个相邻的棋子,在保证棋子移动不超过8次的情况下,问能否把棋盘上的 ...

  5. 搜索+剪枝 POJ 1416 Shredding Company

    POJ 1416 Shredding Company Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 5231   Accep ...

  6. POJ 1416 Shredding Company【dfs入门】

    题目传送门:http://poj.org/problem?id=1416 Shredding Company Time Limit: 1000MS   Memory Limit: 10000K Tot ...

  7. Shredding Company (hdu 1539 dfs)

    Shredding Company Time Limit: 5000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others ...

  8. POJ 1416:Shredding Company

    Shredding Company Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 4713   Accepted: 2714 ...

  9. poj1416 Shredding Company

    Shredding Company Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 5379   Accepted: 3023 ...

随机推荐

  1. HDU 1561 树形DP入门

    The more, The Better Time Limit: 6000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Oth ...

  2. Wince 6.0 窗口最大化显示

    在InitDialog用如下代码实现: CRect   m_FullScreenRect;   //全屏区域 CRect   WindowRect; GetWindowRect(&Window ...

  3. 【转】NHibernate:no persister for 异常

    1.配置文件后缀名写错 mapping file 必须是.hbm.xml结尾 2.Web.config配置里面引用实体 <session-factory> <mapping asse ...

  4. Python的平凡之路(6)

    一.面向对象编程介绍 1 编程范式:          编程范式(Programming Paradigm)是某种编程语言典型的编程风格或者说是编程方式.随着编程方法学和软件工程研究的深入,特别是OO ...

  5. (zz) 谷歌技术"三宝"之BigTable

    006年的OSDI有两篇google的论文,分别是BigTable和Chubby.Chubby是一个分布式锁服务,基于Paxos算法:BigTable是一个用于管理结构化数据的分布式存储系统,构建在G ...

  6. cookie窃取和session劫持

    Updates 2014-08-17 感谢@搞前端的crosser的提醒,加入了HTTP Response Splitting的内容. 此篇文章的Presentation戳这里. 一.cookie的基 ...

  7. Gradle for Android

    1.project vs project.rootProject 2.System.console() != null ? System.console().readPassword("\n ...

  8. laravel_5《数据库迁移》

    Laravel鼓励敏捷.迭代的开发方式,我们没指望在第一次就获得所有正确的.相反,我们编写代码.测试和与我们的最终用户进行交互,并完善我们的理解. 对于工作,我们需要一个配套的实践集.我们使用像sub ...

  9. import和from import陷阱二

    1 2 3 4 5 6 7 8 9 10 11 12 13 14 #from os import path import os.path path='/home/vamei/doc/file.txt' ...

  10. java 代码的细节优化

    前言 代码优化,一个很重要的课题.可能有些人觉得没用,一些细小的地方有什么好修改的,改与不改对于代码的运行效率有什么影响呢?这个问题我是这么考虑 的,就像大海里面的鲸鱼一样,它吃一条小虾米有用吗?没用 ...