小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

刷題--DFS--823.排列

 行者花雕 2021-06-24

DFS

823.排列

給定一個整數(shù)n,將數(shù)字1~n排成一排,將會有很多種排列方法。

現(xiàn)在,請你按照字典序?qū)⑺械呐帕蟹椒ㄝ敵觥?/p>

輸入格式

共一行,包含一個整數(shù)n。

輸出格式

按字典序輸出所有排列方案,每個方案占一行。

數(shù)據(jù)范圍

1≤n≤91≤n≤9

輸入樣例:

3

輸出樣例:

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

思維過程:

?1.畫出遞歸數(shù)

2.思考遞邊界與如何遞歸出該樹:

? 1)每層的父節(jié)點有n個分支

?2)樹高為n

?3)放置數(shù)值時候,子節(jié)點是無法再次放置同樣的數(shù)值的,所以需要設(shè)置一個標(biāo)識 bool state[n]。如1_ _,放置了1之后,就在state數(shù)組里i=1的值設(shè)為true,代表已經(jīng)用過。值得思考的是,在遞歸樹中,子節(jié)點返回父節(jié)點的時候,得將設(shè)置的true恢復(fù)為false. 如 1_ _,返回后,就得將state[1]置為false,因為在2_ _這個遞歸中,1是可以被使用的。 以下是代碼:

#include <iostream>
#include <memory.h>
using namespace std;

//代表數(shù)組的長度,同時也是遞歸樹的高度
int n;
//保存值的數(shù)組
int s[10];
//保存了哪些數(shù)據(jù)已經(jīng)用過了,下標(biāo)代表數(shù)據(jù),值代表是否用過
bool state[10];
void dfs(int n1) {
    //邊界,說明已經(jīng)排列完了一次
    if (n1 == n) {
        for (int i = 0; i < n; i++) cout << s[i]+1<<" ";
        cout << endl;
        return;
    }

    for (int i = 0; i < n; i++) {
         //說明未被使用過
        if (state[i] == false) {
            //進(jìn)行s填充,并將相應(yīng)標(biāo)志位置為true
            s[n1] = i; 
            state[i] = true;
            //進(jìn)行下一次dfs
            dfs(n1 + 1);
            //回到上一層后,將原來修改為true的state恢復(fù)現(xiàn)場為false
            state[i] = false;
        }       
    }
}

int main() {
    cin >> n;
    dfs(0);
}

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多