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

溫馨提示×

溫馨提示×

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

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

枚舉排列

發布時間:2020-08-04 08:07:39 來源:網絡 閱讀:703 作者:YXQiang 欄目:編程語言

生成1~n的排列
我們嘗試用遞歸的思想解決:先輸出以1開頭的排列(這一步是遞歸調用),然后輸出以2開頭的排列(又是遞歸調用),接著是以3為開頭的排列.....最后才是以n開頭的排列。
以1開頭的排列的特點是:第一位是1,后面是2~9的排列。根據字典序的定義,這些2~9的排列也必須按照字典序排列。換句話說,需要“按照字典序輸出2~9的排列”,不過需要注意的是,在輸出時,每個排列的最前面要加上“1”。這樣一來,所設計的遞歸偽碼如下:
void print_permutation(序列A,集合S){
if(S為空) 輸出序列A;
else 按照從小到大的順序依次考慮S的每個元素V{
print_permutation(在A末尾填加V后得到的新序列,S-{V});}
}
下面考慮程序實現。不難想到用數組表示序列A,而集合S根本不用保存。因為,它可以由序列A完全確定——A中沒有出現的元素都可以選。同時,我們還需要一個參數記錄當前需要確定的位置cur,代碼如下:


#include"stdio.h"
#include"stdlib.h"
void print_permutation(int *A,int n,int cur){
    if(cur==n){
        for(int i=0;i<n;i++)
        printf("%3d",A[i]);
        printf("\n");
        return;
    }
    else{
        for(int i=1;i<=n;i++){
            int k=1;
            for(int j=0;j<cur;j++){
                if(A[j]==i){
                    k=0;
                    break;
                }
            }
            if(k){
                A[cur]=i;
                print_permutation(A,n,cur+1);
            }
        }
    }
}
int main()
{
    int n;
    scanf("%d",&n);
    int *A=(int *)malloc(sizeof(int)*n);
    print_permutation(A,n,0);
    free(A);
    return 0;
}
由于小編水平有限,歡迎讀者發現錯誤并指正。
下期,小編將帶來如何實現型如“1 1 1”序列的全排列
向AI問一下細節
推薦閱讀:
  1. 枚舉
  2. java 枚舉

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

AI

梅河口市| 西充县| 汨罗市| 外汇| 峨山| 搜索| 澄迈县| 丘北县| 黄骅市| 玉树县| 平罗县| 龙口市| 迁安市| 沙洋县| 东辽县| 巍山| 闵行区| 巩留县| 颍上县| 尖扎县| 康平县| 龙南县| 鹿邑县| 比如县| 太原市| 南宫市| 黔西| 淮南市| 肥城市| 新野县| 东山县| 东阿县| 肇东市| 南通市| 吉木乃县| 贺州市| 栖霞市| 德清县| 手游| 商城县| 大荔县|