溫馨提示×

溫馨提示×

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

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

如何編寫字母全排列快速算法C代碼

發(fā)布時間:2021-10-14 14:46:12 來源:億速云 閱讀:125 作者:柒染 欄目:編程語言

這篇文章給大家介紹如何編寫字母全排列快速算法C代碼,內(nèi)容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

全排列,比如字母ABC,所有排列有A ,AB,AC,ABC,ACB,B,BA,BC,BAC,BCA,C,CA,CB,CAB,CBA。

如何編寫字母全排列快速算法C代碼//原理是插入, 在一個字符串的所有位置插入新字符.
如何編寫字母全排列快速算法C代碼//如: AB 插入C , 位置有 1A2B3, 插入后形成 CAB ACB ABC
如何編寫字母全排列快速算法C代碼
如何編寫字母全排列快速算法C代碼char *AllList(char *str, int *pNum)
如何編寫字母全排列快速算法C代碼如何編寫字母全排列快速算法C代碼...{
如何編寫字母全排列快速算法C代碼    int i, j, k, n;
如何編寫字母全排列快速算法C代碼    int len = strlen(str);
如何編寫字母全排列快速算法C代碼    int Total = 0;
如何編寫字母全排列快速算法C代碼    int count, oldcount;
如何編寫字母全排列快速算法C代碼    int size;
如何編寫字母全排列快速算法C代碼    char *Buf;
如何編寫字母全排列快速算法C代碼    char *p, *p1;
如何編寫字母全排列快速算法C代碼
如何編寫字母全排列快速算法C代碼    if (len > 10) return NULL;
如何編寫字母全排列快速算法C代碼
如何編寫字母全排列快速算法C代碼    //計算總的組合數(shù)目
如何編寫字母全排列快速算法C代碼    for (i = 0, j = 1; i  len; i++)
如何編寫字母全排列快速算法C代碼如何編寫字母全排列快速算法C代碼    ...{
如何編寫字母全排列快速算法C代碼        j *= (len - i);
如何編寫字母全排列快速算法C代碼        Total += j;
如何編寫字母全排列快速算法C代碼    }

如何編寫字母全排列快速算法C代碼
如何編寫字母全排列快速算法C代碼    //創(chuàng)建二維數(shù)組, 存放全部組合
如何編寫字母全排列快速算法C代碼    size = len + 1;
如何編寫字母全排列快速算法C代碼    if ((Buf = (char *)malloc(Total * size)) == NULL)
如何編寫字母全排列快速算法C代碼如何編寫字母全排列快速算法C代碼    ...{
如何編寫字母全排列快速算法C代碼        return NULL;
如何編寫字母全排列快速算法C代碼    }

如何編寫字母全排列快速算法C代碼
如何編寫字母全排列快速算法C代碼    for (k = 0, count = 0; k  len; k++)  //所有要插入的字符
如何編寫字母全排列快速算法C代碼如何編寫字母全排列快速算法C代碼    ...{
如何編寫字母全排列快速算法C代碼        oldcount = count;
如何編寫字母全排列快速算法C代碼        p = Buf;
如何編寫字母全排列快速算法C代碼        p1 = Buf + count * size;
如何編寫字母全排列快速算法C代碼        for (i = 0; i  oldcount; i++, p += size)  //插入到所有字符串中,形成新的字符串
如何編寫字母全排列快速算法C代碼如何編寫字母全排列快速算法C代碼        ...{
如何編寫字母全排列快速算法C代碼            n = strlen(p);
如何編寫字母全排列快速算法C代碼            for (j = 0; j  n; j++, count++, p1 += size) //在字符串所有位置插入
如何編寫字母全排列快速算法C代碼如何編寫字母全排列快速算法C代碼            ...{
如何編寫字母全排列快速算法C代碼                memcpy(p1, p, n);
如何編寫字母全排列快速算法C代碼                p1[n] = p1[j];
如何編寫字母全排列快速算法C代碼                p1[j] = str[k];
如何編寫字母全排列快速算法C代碼                p1[n + 1] = '

 在我的機器上排列10個字母大約0.5秒。
 

關(guān)于如何編寫字母全排列快速算法C代碼就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

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

AI