简单深搜: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. 现在请在数列中插入“+”表示加,或者“-”表示减,抑或是“ ”表示空白,来将 ...
随机推荐
- JUC组件扩展(三):BlockingQueue(阻塞队列)详解
一. 前言 在新增的Concurrent包中,BlockingQueue很好的解决了多线程中,如何高效安全“传输”数据的问题.通过这些高效并且线程安全的队列类,为我们快速搭建高质量的多线程程序带来极大 ...
- GameObject非激活状态,触发测试
测试结果为OnEnable,Start不执行.Awake不管激活未激活都执行 不管是驻留在层级面板,还是手动拖上去. 但是,在任何时间设为激活.就会2个都触发.Awake和Start只触发一次.这个问 ...
- [转]html5调用摄像头实例
原文:https://blog.csdn.net/binquan_liang/article/details/79489989 最近在学习在做HTML5的项目,看了博客上html5调用摄像头拍照的文章 ...
- Object-C支持多继承吗?可以实现多个接口吗?Category是什么?
转自:http://blog.sina.com.cn/s/blog_7afd7d7801016t3t.html Object-C支持多继承吗?可以实现多个接口吗?Category是什么?重写一个类的方 ...
- KVM部署LVS集群故障案例一则
一.故障现象 KVM部署LVS(Linux Virtual Server)集群后,能够单独以HTTP方式访问RS(Real Server)的实际IP,但无法通过VIP(Virtual IP)访问. 二 ...
- # mysqlbinlog mysql-bin.000004 mysqlbinlog: unknown variable 'default-character-set=utf8'
# mysqlbinlog mysql-bin.000004 mysqlbinlog: unknown variable 'default-character-set=utf8' 加上--no-def ...
- 判断是否是IE浏览器和是否是IE11
判断是否是IE浏览器用下面这个函数, function isIE() { //ie? 是ie返回true,否则返回false if (!!window.ActiveXObject || "A ...
- Qt禁止调整窗口的大小
项目中使用的是基于对话框的程序,所以限制调整窗口大小会比较合适,下面是两种方法. 1.使用代码修改 #include "dialog.h" #include "ui_di ...
- chrome 插件地址 知乎
chrome运行内存过大:https://www.zhihu.com/question/20061319 chrome扩展程序:https://www.zhihu.com/question/19594 ...
- Extjs,实现树形结构的总结
工作总结,用extjs.mybatis.springMVC实现树形显示班级 前台extjs实现树形代码如下: xtype : 'combotree', fieldLabel : '部门名称', nam ...