简单深搜: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. 现在请在数列中插入“+”表示加,或者“-”表示减,抑或是“ ”表示空白,来将 ...
随机推荐
- windows 2003 群集
http://www.tudou.com/programs/view/-UZoSIuUvXs/
- CentOS中安装JDK与Intellij idea
卸载CentOS中自带openjdk CentOS自带openjdk,可以先用java –version检测是否存在jdk版本.如果存在,最好在安装oracle的jdk之前最好卸载,可以使用如下指令 ...
- RPC服务框架dubbo(六):Consumer搭建过程
1.在pom.xml中除了ssm的依赖添加dubbo相关3个依赖(接口,dubbo.jar,zkClient) 2.web.xml中修改<init-value>applicationCon ...
- maven ArtifactTransferException:failure
手动下载对应jar放在本地仓库 -> Update Dependencies(Maven4Myeclipse:eclipse上maven插件)
- Ubuntu14.04.3 64位环境下openjdk7编译
系统环境:Ubuntu14.04.3 -amd64 in VMWare1.安装openjdk7依赖 sudo apt- sudo apt--jdk sudo apt-get install build ...
- @XStreamAlias使用
@XStreamAlias使用 一. 特点: 简化的API; 无映射文件; 高性能,低内存占用; 整洁的XML; 不需要修改对象;支持内部私有字段,不需要setter/getter方法 提供序列化接口 ...
- Ubuntu 12.04 Subversion及GUI客户端RabbitVCS安装
(经过一天的使用,发现pygtk的内存泄漏问题严重影响使用,需要打一下deepin ui做的补丁:https://github.com/linuxdeepin/deepin-ui) 1. 类似Tort ...
- [开机启动]Linux开机自启和运行级别
嵌入式系统中程序自启动方法 在很多嵌入式系统中,由于可用资源较少,常常在系统启动后就直接让应用程序自动启动,以减少用户操作和节省资源.如何让自己的应用程序自动启动呢? 在Linux系统中,配置应 ...
- call_usermodehelper内核中运行用户应用程序
init是用户空间第一个程序,在调用init前程序都运行在内核态,之后运行init时程序运行到用户态. 操作系统上,一些内核线程在内核态运行,它们永远不会进入用户态.它们也根本没有用户态的内存空间.它 ...
- codeforces 429 On the Bench dp+排列组合 限制相邻元素,求合法序列数。
限制相邻元素,求合法序列数. /** 题目:On the Bench 链接:http://codeforces.com/problemset/problem/840/C 题意:求相邻的元素相乘不为平方 ...