
字母全排列快速算法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秒。
2017年计算机二级C++辅导实例编程:字母全排列快速算法C代码.doc正在阅读:
2017年计算机二级C++辅导实例编程:字母全排列快速算法C代码09-07
高中教师节感谢恩师作文600字07-29
七年级历史下册期中试卷及答案新版本11-25
初中数学教学计划课件(集锦5篇)08-19
霸气高考对联大全集05-08
2017年湖南省长沙市政府法制办公室所属事业单位招聘公告02-09
2019年商务英语中级翻译练习题(3)02-20
2018四川省德阳市口腔医院招聘报名12月24日—25日09-05
简短儿童故事02-08
一道靓丽的风景作文400字07-22