日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

刷題--DFS--823.排列

 行者花雕 2021-06-24

DFS

823.排列

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

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

輸入格式

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

輸出格式

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

數(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é)點(diǎn)有n個(gè)分支

?2)樹高為n

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

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

//代表數(shù)組的長(zhǎng)度,同時(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)場(chǎng)為false
            state[i] = false;
        }       
    }
}

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

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

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多