caioj 1031: [视频]递归1(全排列)【DFS】【全排列】
题目大意:先给一个正整数 n( 1 < = n < = 10 ),输出1到n的所有全排列。
题解:这道题目我们可以用递归来实现,递归在图论中又称为“深度优先搜索”(Depth First Search,DFS),所以在平时我们经常把用到递归的算法简称为DFS。
我们假设a[i]表示当前排列第i个数的值,用vis表示在当前递归的时候数值i有没有出现在之前的排列数中,则我们可以用下面的dfs(int index)来实现找出全排列的算法。
其中,index表示当前判断到第index个排列数(即编号从0到i-1这前i个排列中的数已经找好了,现在在找第i个排列数)。
代码如下:
#include <cstdio>
#include <cstring>
int n, a[11];
bool vis[11];
void output()
{
printf("%d", a[0]);
for (int i = 1; i < n; i ++)
printf(" %d", a[i]);
printf("\n");
}
void dfs(int idx)
{
if (idx == n)
{
output();
return;
}
for (int i = 1; i <= n; i ++)
{
if (!vis[i])
{
vis[i] = true;
a[idx] = i;
dfs(idx+1);
vis[i] = false;
}
}
}
int main()
{
while (~scanf("%d", &n))
{
memset(vis, false, sizeof(vis));
dfs(0);
}
return 0;
}
除此之外,C++的STL中的algorithm库中为我们提供了next_permutation函数,它用于根据当前的排列推测出接下来的那个排列。
我们现在可能还没有接触到排列组合的问题,但是学过排列组合问题以后我们将会知道1到n这n个数能够组成的排列的个数是n!(=n(n-1)……*1)
所以我们可以开一个for循环,循环体内调用next_permutation,知道找到n!个排列,代码如下:
#include <cstdio>
#include <algorithm>
using namespace std;
int n, a[11];
void output()
{
printf("%d", a[0]);
for (int i = 1; i < n; i ++)
printf(" %d", a[i]);
printf("\n");
}
int main()
{
while (~scanf("%d", &n))
{
int tot = 1;
for (int i = 2; i <= n; i ++)
tot *= i;
for (int i = 0; i < n; i ++)
a[i] = i + 1;
output();
for (int i = 1; i < tot; i ++)
{
next_permutation(a, a+n);
output();
}
}
return 0;
}
caioj 1031: [视频]递归1(全排列)【DFS】【全排列】的更多相关文章
- for循环枚举法,全排列+dfs,补充浮点数注意事项
其实这个题目我一直没想好应该叫什么,就是在做蓝桥杯的时候会遇到很多的题,给你一等式,abcdef...分别是1-9(||12||15)不重复问你有几种方案? 我之前一直都是用的for循环在做,听说这叫 ...
- 数的全排列 dfs深度优先搜索
数的全排列. 输入格式: 一个n(n<10),表示长度 输出格式: 按字典序输出长度为n的所有排列,每个排列后需要换行,每个排列数字以空格分开. 输入样例: 在这里给出一组输入.例如: 3 输出 ...
- dfs 全排列 使用交换——含重复元素和非重复元素
15. 全排列 中文 English 给定一个数字列表,返回其所有可能的排列. 样例 样例 1: 输入:[1] 输出: [ [1] ] 样例 2: 输入:[1,2,3] 输出: [ [1,2,3], ...
- 组合数学(全排列)+DFS CSU 1563 Lexicography
题目传送门 /* 题意:求第K个全排列 组合数学:首先,使用next_permutation 函数会超时,思路应该转变, 摘抄网上的解法如下: 假设第一位是a,不论a是什么数,axxxxxxxx一共有 ...
- uva 10344 23 out of 5 凑运算结果 全排列+dfs
五个数三个运算符号,排列之后凑成结果为23,不考虑优先级. 很水,数据量也不大,先生成五个数的全排列,用dfs找出结果能否为23即可. 代码: #include <cstdio> #inc ...
- 全排列——DFS实现
原创 之间就写过一篇全排列的博客:https://www.cnblogs.com/chiweiming/p/8727164.html 详细介绍请回看,用的方法(暂且就叫)是“交换法”,其实思路就是DF ...
- zzulioj--1730--通信基站(全排列+dfs)(好题)
1730: 通信基站 Time Limit: 1 Sec Memory Limit: 128 MB Submit: 28 Solved: 11 SubmitStatusWeb Board Desc ...
- 递归实现1-n的全排列(JAVA语言)
思路: For example: 123的全排列= 1在最前面 23的全排列 + 2在最前面 13的全排列 + 3最前面 12的全排列 所以只需交换和最前面元素的位置,生成剩余元素的全排列即可. im ...
- 全排列dfs算法
如下 #include <iostream> using namespace std; #define MAX 10 #define _CRT_SECURE_NO_WARNINGS int ...
随机推荐
- tp5 商城商品模型删除
1:控制器代码 public function delete($id) { //验证id是否正确 $id if (!intval($id)) { return getJsonData(10010, ' ...
- 11 Java的方法 递归
6.递归 A方法调用B方法,我们很容易理解! 递归就是:A方法调用A方法!就是自己调用自己 利用递归可以用简单的程序来解决一些复杂的问题. 它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较 ...
- netty通信
学习netty之前,要先了解操作系统中的IO.零拷贝(已经附上链接了) 一.netty的简单介绍 Netty 是由 JBOSS 提供的一个 Java 开源框架,现为 Github 上的独立项目. Ne ...
- python学习之scipy实战1(积分用法)
import numpy as np def main(): #1-- Integral积分 from scipy.integrate import quad, dblquad, nquad prin ...
- [SWPU2019] NETWORK
[SWPU2019]Network(TTL隐写) 1.题目概述 2.解题过程 文档中的数字代表什么呢?会不会是RGB? 看了一下以前做过的题目,好像并不是 那是什么呢?百度告诉我这是TTL隐写,哇,长 ...
- 从MyIE2平滑升级到Maxthon的完美方案
经过几个Beta版本的测试MyIE2改名为Maxthon的新版浏览器终于发布了正式版本.喜欢MyIE2的朋友们也可以放心的将你的MyIE2升级为Maxthon了.以下是MyIE2平滑过渡到Mathxo ...
- JSON.parse()和JSON.stringfy()区别
JSON.parse() 用于从一个json格式字符串解析出json类型的数据,如: 注意事项:json格式字符串必须是写在一排的,且括号外面用单引号,里面的每一个字符串用双引号 JSON.strin ...
- 什么是CPI
请参考这篇博客,很全面的解释了CPI https://www.cnblogs.com/diegodu/p/9366639.html
- Linux安全加固手册
1 身份鉴别 1.1 密码安全策略 操作系统和数据库系统管理用户身份鉴别信息应具有不易被冒用的特点,口令应有复杂度要求并定期更换. 设置有效的密码策略,防止攻击者破解出密码 ...
- IO、NIO和AIO的区别
IO和NIO的区别:其本质就是阻塞和非阻塞的区别. 阻塞概念:应用程序在获取网络数据的时候,如果网络传输数据很慢,那么久一直等着,知道传输完毕为止.非阻塞概念:应用程序直接可以获取已经准备就绪好的 ...