http://codeup.cn/contest.php

5972

这是递归的入门题,求全排列,第一种方法用STL中的函数next_permutation,可以很容易的实现。首先建立好数组,将需要全排列的数字进行初始化,然后调用next_permutation(a,a+n),按照地址进行全排列打印结果.

#include <stdio.h>
#include <algorithm>
using namespace std;
int a[];
int main()
{
int n;
scanf("%d", &n);
int i;
for (i = ; i < n; i++)
{
a[i] = i + ;
}
do
{
for (i = ; i < n; i++)
{
if (i != n - )
printf("%d ", a[i]);
else
printf("%d", a[i]);
}
printf("\n");
} while (next_permutation(a, a + n));
}

2.另外一种递归写法如下。

#include <bits/stdc++.h>
using namespace std;
vector<int>ans;
bool hashTable[] = { false };//true选false不选
int i;
int n;
void DFS(int index)
{
if (index == n)
{
for (i = ; i < n; i++)
{
if (i != n - )
printf("%d ", ans[i]);
else
printf("%d", ans[i]);
}
printf("\n");
return;
}
for (int x = ; x < n; x++)
{
if (hashTable[x] == false)
{
ans.push_back(x+);//选这个元素
hashTable[x] = true;//将他设置为已选择
DFS(index + );//不选这个元素
ans.pop_back();//弹出
hashTable[x] = false;//把这个元素设置为未选择
}
}
}
int main()
{
scanf("%d", &n);
DFS();
}

5973

和这个题很像,求的是组合,也是DFS递归模板的另一版本.

#include <cstdio>
#include <vector>
using namespace std;
int n, r;
int a[];
vector<int>ans;
void DFS(int index, int v)
{
if (index == n)
{
if (v == r)
{
vector<int>::iterator it = ans.begin();
for (; it != ans.end(); it++)
{
if (it != ans.end() - )
{
printf("%d ", *it);
}
else
printf("%d", *it);
}
printf("\n");
}
return;
}
ans.push_back(a[index]);
DFS(index + , v + );
ans.pop_back();
DFS(index + , v);
}
int main()
{
scanf("%d %d", &n, &r);
int i;
for (i = ; i < n; i++)
{
a[i] = i + ;
}
DFS(, );
}

  

《算法笔记》8.1小节——搜索专题->深度优先搜索(DFS)的更多相关文章

  1. python实现广度优先搜索和深度优先搜索

    图的概念 图表示的是多点之间的连接关系,由节点和边组成.类型分为有向图,无向图,加权图等,任何问题只要能抽象为图,那么就可以应用相应的图算法. 用字典来表示图 这里我们以有向图举例,有向图的邻居节点是 ...

  2. 【数据结构与算法Python版学习笔记】图——骑士周游问题 深度优先搜索

    骑士周游问题 概念 在一个国际象棋棋盘上, 一个棋子"马"(骑士) , 按照"马走日"的规则, 从一个格子出发, 要走遍所有棋盘格恰好一次.把一个这样的走棋序列 ...

  3. 总结A*,Dijkstra,广度优先搜索,深度优先搜索的复杂度比较

    广度优先搜索(BFS) 1.将头结点放入队列Q中 2.while Q!=空 u出队 遍历u的邻接表中的每个节点v 将v插入队列中 当使用无向图的邻接表时,复杂度为O(V^2) 当使用有向图的邻接表时, ...

  4. [算法专题] 深度优先搜索&回溯剪枝

    1. Palindrome Partitioning https://leetcode.com/problems/palindrome-partitioning/ Given a string s, ...

  5. DFS+BFS(广度优先搜索弥补深度优先搜索遍历漏洞求合格条件总数)--09--DFS+BFS--蓝桥杯剪邮票

    题目描述 如下图, 有12张连在一起的12生肖的邮票.现在你要从中剪下5张来,要求必须是连着的.(仅仅连接一个角不算相连)  比如,下面两张图中,粉红色所示部分就是合格的剪取.  请你计算,一共有多少 ...

  6. "《算法导论》之‘图’":深度优先搜索、宽度优先搜索(无向图、有向图)

    本文兼参考自<算法导论>及<算法>. 以前一直不能够理解深度优先搜索和广度优先搜索,总是很怕去碰它们,但经过阅读上边提到的两本书,豁然开朗,马上就能理解得更进一步. 下文将会用 ...

  7. matlab练习程序(广度优先搜索BFS、深度优先搜索DFS)

    如此经典的算法竟一直没有单独的实现过,真是遗憾啊. 广度优先搜索在过去实现的二值图像连通区域标记和prim最小生成树算法时已经无意识的用到了,深度优先搜索倒是没用过. 这次单独的将两个算法实现出来,因 ...

  8. HDU(搜索专题) 1000 N皇后问题(深度优先搜索DFS)解题报告

    前几天一直在忙一些事情,所以一直没来得及开始这个搜索专题的训练,今天做了下这个专题的第一题,皇后问题在我没有开始接受Axie的算法低强度训练前,就早有耳闻了,但一直不知道是什么类型的题目,今天一看,原 ...

  9. 深度优先搜索 DFS 学习笔记

    深度优先搜索 学习笔记 引入 深度优先搜索 DFS 是图论中最基础,最重要的算法之一.DFS 是一种盲目搜寻法,也就是在每个点 \(u\) 上,任选一条边 DFS,直到回溯到 \(u\) 时才选择别的 ...

随机推荐

  1. NFS使用autofs自动挂载

    NFS自动挂载设置在/etc/fstab和/etc/rc.local可能挂载不成功,假如是服务端NFS宕机还可能导致客户端无法启动,可以使用autofs实现自动挂载 安装autofs yum -y i ...

  2. STL 标准模板库

    <vector> 可变长的数组 Vector<int>v int是一个模板参数,这样传进来的都会是int V.push_back(a)将a传进v,且放在最后一个 V.clear ...

  3. Some untracked working tree files would be overwritten by checkout. Please move or remove them before you can checkout. View them

    Some untracked working tree files would be overwritten by checkout. Please move or remove them befor ...

  4. 【魔改】树状数组 牛客多校第五场I vcd 几何+阅读理解

    https://www.nowcoder.com/acm/contest/143/I vc-dimension 题解:分三种情况,组合数学算一下,其中一种要用树状数组维护 技巧(来自UESTC):1. ...

  5. find实现特殊功能示例

    find列出目录下所有文件: # find /shell-script/ # find /shell-script/ -print find列出文件夹中所有开头为text的文件,参数-iname意思忽 ...

  6. piano class 12

    1,不要记谱子,眼睛要一直看着谱子,手指凭感觉找琴键 2,弹的时候一定要按照谱子上标出来的指法弹奏,很重要 3,两只手要会跷跷板弹奏 4,八分音符,一般第二个会比第一个弱一点,但是要看自己感觉 5,慢 ...

  7. gateone安装使用

    下载地址 https://github.com/liftoff/GateOne unzip GateOne-master.zip cd GateOne-master/ python setup.py ...

  8. coreseek搜索

    参考文档地址:http://github.tiankonguse.com/doc/sphinx/

  9. html select控件的jq操作

    html select控件的jq操作 1.判断select选项中 是否存在Value="paraValue"的Item $("#selectid option[@valu ...

  10. El表达式对照表

    设置  session.getAttribute("date" "date") 取得username的值   (String)session.getValue( ...