简单深搜:POJ1546——Sum it up
结束了三分搜索的旅程 我开始迈入深搜的大坑。。
首先是一道比较基础的深搜题目(还是很难理解好么)
POJ 1564 SUM IT UP
大体上的思路无非是通过深搜来进行穷举、匹配
为了能更好地理解深搜 可以尝试去画一下二叉树理解一下,查看遍历的路径
代码还是百度到别人的自己再参悟- -佩服别人的功底啊
先上代码:
/*POJ 1546 Sum it up*/
# include<iostream>
# include<algorithm>
# include<cstdio> using namespace std; int a[], b[],t,n,sum,cnt; bool cmp(int a, int b)
{
return a > b;
} void dfs(int posa,int posb,int sum)
{
if (sum > t)
return;
if (sum == t)
{
cnt++; for (int i = ; i < posb; i++)
{
if (i == )
cout << b[i];
else
cout << "+" << b[i];
} cout << endl;
} for (int i = posa; i < n; i++)
{
b[posb] = a[i];
dfs(i + , posb + , sum + a[i]);
while (a[i] == a[i+]&&i+<n)
i++;//防止重复运算(剪枝)
}
} int main()
{
while (cin >> t >> n)
{
if (t==&&n==)
break;
for (int i = ; i < n; i++)
cin >> a[i];
sort(a, a + n, cmp);//为了按照题目要求进行降序输出,先对初始数组降序排序 printf("Sums of %d:\n", t);
cnt = ;
dfs(, , );
if (!cnt)
printf("NONE\n");
} return ;
}
解释一下实现的方法。首先:数组a用来存放输入的一组数字,数组b用来暂时储存本次深搜路径生成的组合
深搜的主体部分不过多解释。。还是自己画树理解最好
一些细节:1.剪枝:在树的同一层一个数字没必要试两遍,所以如果这一层的下一个元素还是和原来一样就跳过它继续
2.降序:题目要求了降序输出。那么在深搜前直接现对数组a降序排列即可
简单深搜:POJ1546——Sum it up的更多相关文章
- POJ 2386 Lake Counting (简单深搜)
Description Due to recent rains, water has pooled in various places in Farmer John's field, which is ...
- (深搜)Sum It Up -- poj --1564
链接: http://poj.org/problem?id=1564 http://acm.hust.edu.cn/vjudge/contest/view.action?cid=88230#probl ...
- NYoj The partial sum problem(简单深搜+优化)
题目链接:http://acm.nyist.edu.cn/JudgeOnline/problem.php?pid=927 代码: #include <stdio.h> #include & ...
- HDOJ1015(简单深搜)
Safecracker Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total ...
- poj 1562 简单深搜
//搜八个方向即可 #include<stdio.h> #include<string.h> #define N 200 char ma[N][N]; int n,m,vis[ ...
- POJ-1321棋盘问题(简单深搜)
简单搜索step1 POJ-1321 这是第一次博客,题目也很简单,主要是注意格式书写以及常见的快速输入输出和文件输入输出的格式. 递归的时候注意起始是从(-1,-1)开始,然后每次从下一行开始递归. ...
- nyoj587 hdu1045 简单深搜
#include<iostream> #include<cstdio> #include<queue> #include<vector> #includ ...
- poj 2386:Lake Counting(简单DFS深搜)
Lake Counting Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 18201 Accepted: 9192 De ...
- USACO 2.3.3 Zero Sum 和为零(深搜枚举)
Description 请考虑一个由1到N(N=3, 4, 5 ... 9)的数字组成的递增数列:1 2 3 ... N. 现在请在数列中插入“+”表示加,或者“-”表示减,抑或是“ ”表示空白,来将 ...
随机推荐
- MVC与MVP(转)
MVC模式已经出现了几十年了,在GUI领域已经得到了广泛的应用,由于微软ASP.NET MVC Framework的出现,致使MVC一度成为.NET社区的热名话题.作为MVC的变种MVP模式,也已经出 ...
- hdu5293 Tree chain problem 树形dp+线段树
题目:pid=5293">http://acm.hdu.edu.cn/showproblem.php?pid=5293 在一棵树中,给出若干条链和链的权值.求选取不相交的链使得权值和最 ...
- SEH, SAFESEH相关
SEH, SAFESEH相关 1,触发seh异常让目标程序Read/Write无效地址,如果和栈底相邻的内存只读,尝试覆盖超出栈底 2,如何找到(显示)要覆盖的SEHod语法:dd fs:[0]sof ...
- linux(二十一):apache服务配置(二)
1.普通用户进入家文件夹 紧接着之前的进度,我们想想博客的实现.每一个用户在登录之后.都是在自己的家文件夹.那么对于我们的要求就是要设置每一个用户的默认公布文件夹为其家文件夹. 接着我们就来实现 ...
- java工程资源文件夹嵌套建立!
做过一遍忘了,找了半天!记这里,看你还忘不忘!
- 每日英语:The Perils Of Giving Advice
I know what you should do and here's my advice. How many times have you heard that (and groaned)? gr ...
- jvm垃圾收集器之Throughput GC
呃.HotSpot VM的GC组老人之一Jon Masamitsu很久之前就写过blog讲解这个:https://blogs.oracle.com/jonthecollector/entry/our_ ...
- line: 1: Syntax error: word unexpected (expecting ")")
开发板上运行可执行程序报出错误: line1: 1: Syntax error: word unexpected (expecting ")") 解决思路: 1.编译器的问题 用a ...
- 使用ICSharpCode.TextEditor制作一个语法高亮显示的XML编辑器
使用ICSharpCode.TextEditor制作一个语法高亮显示的XML编辑器 品高工作流 的流程模拟器中使用了一个具有语法高亮和折叠功能的XML编辑器,其核心就是用了SharpDevelop中的 ...
- Extjs,实现树形结构的总结
工作总结,用extjs.mybatis.springMVC实现树形显示班级 前台extjs实现树形代码如下: xtype : 'combotree', fieldLabel : '部门名称', nam ...