91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C++全排列中遞歸交換法怎么用

發布時間:2022-04-16 11:01:53 來源:億速云 閱讀:113 作者:iii 欄目:編程語言

今天小編給大家分享一下C++全排列中遞歸交換法怎么用的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

題目描述

輸出自然數1到n所有不重復的排列,即n的全排列,要求所產生的任一數字序列中不允許出現重復的數字。

輸入格式

一個整數n。

輸出格式

由1~n組成的所有不重復的數字序列,每行一個序列。

每個數字保留 5個場寬。

輸入樣例

3

輸出樣例

1 2 3
1 3 2
2 1 3
2 3 1
3 1 2
3 2 1

全排列問題——遞歸交換法

其實跟暴力枚舉思路差不多,每次遞歸枚舉第x個數字是幾,之后a[x]可以選擇不動,也可以選擇與后面任意一個數交換位置,就是從后面選一個數放到x的位置上。

簡而言之,就是每到一位就從后面選一個尚未被使用過的數字與該位數字交換,這里有些難理解,您可以自己按照程序推一下樣例。

這樣我們就可以打印所有的全排列了,但這樣不是按順序打印,所以這里需要每次對a[x] ~ a[n]進行排序。

舉個例子,如對1、2、3進行全排列。當我們交換1和3后,序列變為3、2、1,如果說這里不排序,直接2、1都保持不動,就輸出3、2、1了,可是我們先要的應該是3、1、2,所以要進行排序。

最后,算一下時間復雜度,我們發現需要從1到n一位一位的看,之后每位還要枚舉x ~ n,所以總時間復雜度為O(n!)。

代碼

# include <cstdio>
# include <cmath>
# include <cstring>
# include <algorithm>

using namespace std;

const int N_MAX = 10;

int n;
int a[N_MAX + 10];

void permutation(int x)
{
 if (x == n) {
  for (int i = 1; i <= n; i++)
   printf("%5d", a[i]);
  printf("\n");
  return;
 }
 for (int i = x; i <= n; i++) {
  sort(a + x, a + n + 1);
  swap(a[x], a[i]);
  permutation(x + 1);
  swap(a[x], a[i]);
 }
}

int main()
{
 scanf("%d", &n);
 for (int i = 1; i <= n; i++)
  a[i] = i;
 permutation(1);
 return 0;
}

以上就是“C++全排列中遞歸交換法怎么用”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

c++
AI

桐乡市| 景泰县| 自治县| 广德县| 贵阳市| 呼伦贝尔市| 双桥区| 桦南县| 赫章县| 光山县| 五峰| 乳山市| 嵊州市| 金坛市| 松原市| 密云县| 河南省| 桂东县| 双辽市| 友谊县| 墨竹工卡县| 乌鲁木齐县| 永顺县| 盖州市| 高陵县| 宁波市| 府谷县| 浙江省| 平南县| 盐城市| 盐源县| 基隆市| 景德镇市| 彝良县| 逊克县| 贺州市| 永登县| 车险| 济宁市| 普宁市| 晴隆县|