程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> 關於C語言 >> 字母全排列快速算法C代碼

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

編輯:關於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秒。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved