日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

字母全排列快速算法C代码

發布時間:2025/5/22 编程问答 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 字母全排列快速算法C代码 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

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

//原理是插入, 在一個字符串的所有位置插入新字符.
//如: AB 插入C , 位置有 1A2B3, 插入后形成 CAB ACB ABC

char *AllList(char *str, int *pNum)
...{
??? int i, j, k, n;
??? int len = strlen(str);
??? int Total = 0;
??? int count, oldcount;
??? int size;
??? char *Buf;
??? char *p, *p1;

??? if (len > 10) return NULL;

??? //計算總的組合數目
??? for (i = 0, j = 1; i < len; i++)
??? ...{
??????? j *= (len - i);
??????? Total += j;
??? }

??? //創建二維數組, 存放全部組合
??? size = len + 1;
??? if ((Buf = (char *)malloc(Total * size)) == NULL)
??? ...{
??????? return NULL;
??? }

??? for (k = 0, count = 0; k < len; k++)? //所有要插入的字符
??? ...{
??????? oldcount = count;
??????? p = Buf;
??????? p1 = Buf + count * size;
??????? for (i = 0; i < oldcount; i++, p += size)? //插入到所有字符串中,形成新的字符串
??????? ...{
??????????? n = strlen(p);
??????????? for (j = 0; j <= n; j++, count++, p1 += size) //在字符串所有位置插入
??????????? ...{
??????????????? memcpy(p1, p, n);
??????????????? p1[n] = p1[j];
??????????????? p1[j] = str[k];
??????????????? p1[n + 1] = '
?在我的機器上排列10個字母大約0.5秒。

總結

以上是生活随笔為你收集整理的字母全排列快速算法C代码的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。