社区
数据结构与算法
帖子详情
1--N的全排列,谁有算法,急用
IloveMint
2002-07-10 08:37:44
同上
...全文
42
3
打赏
收藏
1--N的全排列,谁有算法,急用
同上
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
3 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
LeeMaRS
2002-07-10
打赏
举报
回复
http://www.csdn.net/expert/topic/843/843002.xml?temp=.4877893
这里有算法 还有讲解.
laughcry2002
2002-07-10
打赏
举报
回复
这是我刚写的一个:
/* COPYRIGHT 2002 by LaughCry */
/*
Enumerate all the N! permutation(s) of 0..N-1
*/
#include <stdio.h>
#define N 4
#define TRUE 1
#define FALSE 0
void main(void)
{
char used[N], perm[N], i, n;
long cnt = 0;
int top = -1;
for(i=0; i<N; i++) used[i] = FALSE;
while(1){
for(i=0; i<N; i++)
if(!used[i]){
perm[++top] = i; /* push i */
used[i] = TRUE;
}
/* print_out */
printf("\n%-8ld", ++cnt);
for(i=0; i<N; i++) printf("%d ", perm[i]);
do{
if(top == -1) goto done; /* end */
n = perm[top--]; /* pop n */
used[n] = FALSE;
for(i = n+1; i < N && used[i]; i++);
}while(i >= N); /* not found */
perm[++top] = i; /* push a num */
used[i] = TRUE;
}
done:
printf("\ntotal: %ld\n", cnt);
}
laughcry2002
2002-07-10
打赏
举报
回复
这是我师弟做的一个程序:
/*
* 求N个数的所有可能的排列(共N!种)并输出。
*/
#include "stdio.h"
struct num{
int n;
struct num *nextPtr;
};
typedef struct num NUM;
typedef NUM * NUMPTR;
/*总根-- 最后一个数a={1}*/
NUM a={1};
NUMPTR zongPtr,endPtr,headPtr;
void putout(NUMPTR);
void freeout(NUMPTR);
void move(NUMPTR);
void move3(NUMPTR);
void change(NUMPTR);
int num,k=0;
main()
{
int i;
NUMPTR deadPtr,newPtr,startPtr;
headPtr=(NUMPTR)malloc(sizeof(NUM));
startPtr=&a;
printf("Enter the number:")
scanf("%ld",&num);
for(i=num;i>=2;i--)
{
newPtr=(NUMPTR)malloc(sizeof(NUM));
startPtr->nextPtr=newPtr;
newPtr->n=i;
startPtr=newPtr;
}
startPtr->nextPtr=&a;
endPtr=&a;
zongPtr=a.nextPtr;
/*领头head*/
headPtr->nextPtr=zongPtr;
move3(headPtr);
freeout(headPtr);
printf("\n%d groups!\n",k);
return 0;
}
/*打印*/
void putout(NUMPTR nPtr)
{
int i;
NUMPTR putPtr;
putPtr=nPtr;
k++;
for(i=0;i<num;i++){
putPtr=putPtr->nextPtr;
printf("%ld ",putPtr->n);
}
printf("\t");
}
/**释放链表*/
void freeout(NUMPTR freePtr)
{
NUMPTR deadPtr;
int i;
for(i=0;i<=num;i++){
deadPtr=freePtr;
freePtr=freePtr->nextPtr;
free(deadPtr);
}
}
/*最后三个数的全排列*/
void move(NUMPTR startPtr)
{
int temp=startPtr->n;
if(startPtr->nextPtr==endPtr)
change(startPtr);
else
{
do{
move(startPtr->nextPtr);
putout(headPtr);
change(startPtr);
putout(headPtr);
}while(startPtr->n!=temp);
}
}
/*此函数用于最后三个数首尾交换*/
void change(NUMPTR startPtr)
{
int temp=startPtr->n;
startPtr->n=endPtr->n;
endPtr->n=temp;
}
/*大于3个数时*/
void move3(NUMPTR startPtr)
{
int temp=startPtr->nextPtr->n;
if(startPtr->nextPtr->nextPtr->nextPtr==endPtr)
move(startPtr->nextPtr);
else
while(1)
{
move3(startPtr->nextPtr);
/*转一位*/
endPtr->nextPtr=startPtr->nextPtr;
startPtr->nextPtr=startPtr->nextPtr->nextPtr;
endPtr=endPtr->nextPtr;
if(startPtr->nextPtr->n==temp)
{
/*向前转一位*/
endPtr->nextPtr=startPtr;
break;
}
}
}
Algorithms.
算法
概论.习题答案
\[ F_n > \phi^{n-1} \] 其中,\( \phi = \frac{1+\sqrt{5}}{2} \) 是黄金分割率。这表明斐波那契数列的增长速率与黄金分割紧密相关,展示了数学的美丽和统一性。 ### 知识点四:矩阵乘法的复杂度分析 文档分析了...
算法
技术手册 - 中文版
《
算法
技术手册》内容简介:开发健壮的软件需要高效的
算法
,然后程序员们往往直至问题发生之时,才会去求助于
算法
。《
算法
技术手册》讲解了许多现有的
算法
,可用于解决各种问题。通过阅读它,可以使您学会如何选择和...
数据结构+
算法
综合资料库
常见的
算法
有排序(冒泡排序、选择排序、快速排序、归并排序等)、查找(顺序查找、二分查找、哈希查找等)、图
算法
(深度优先搜索、广度优先搜索、最短路径
算法
等)以及动态规划、贪心策略和回溯
算法
等。...
java
算法
大全(含源码包)
1. **排序
算法
**:包括快速排序、归并排序、冒泡排序、插入排序、选择排序、希尔排序、堆排序等。排序
算法
是数据处理中的基础,它们用于将一组数据按照特定顺序进行排列。 2. **查找
算法
**:如二分查找、线性查找、...
jd-gui.exe反编译查看工具包官方绿色版
jd-gui.exe通过分析.class文件中的指令和常量池,利用一定的
算法
推测出原始的源代码结构。尽管反编译无法完全恢复原始的源代码,但通常可以提供足够清晰的理解,以便进行调试、学习或者研究。 三、jd-gui.exe的主要...
数据结构与算法
33,028
社区成员
35,336
社区内容
发帖
与我相关
我的任务
数据结构与算法
数据结构与算法相关内容讨论专区
复制链接
扫一扫
分享
社区描述
数据结构与算法相关内容讨论专区
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章