| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2705 人关注过本帖
标题:关于全排列
只看楼主 加入收藏
墨斗鱼
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2006-4-10
收藏
 问题点数:0 回复次数:13 
关于全排列
我们出了一道极富挑战性的编程题,在20秒内输出一个整数N(1<=N<=10)的全排列,要求字典序,我的程序编出来了,但是输出8的全排列都要15秒,10的话要好几分钟,各位大侠有没有快一点的算法呢,谢谢了!
搜索更多相关主题的帖子: 排列 整数 挑战性 算法 
2006-04-10 22:59
sunnvya
Rank: 5Rank: 5
等 级:贵宾
威 望:17
帖 子:1094
专家分:0
注 册:2005-11-23
收藏
得分:0 
从小到大?最坏情况下20秒?
俺来!等着!

http://www. 第二站>>>提供源码下载
2006-04-11 07:42
qzt040613
Rank: 3Rank: 3
等 级:新手上路
威 望:6
帖 子:63
专家分:0
注 册:2006-3-15
收藏
得分:0 
我等着

天地无极,我本逍遥!
2006-04-13 19:38
墨斗鱼
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2006-4-10
收藏
得分:0 
标准算法

这个问题的算法是不断替换查找法,但是我分析根本不可能在20秒内全部输出,因为这取决与你的计算机,从1输出到10!都不止这个时间的,我的全排列算法如下:
/*
由一个排列a[1]a[2]...a[n]生成下一个排列的算法:
a) i=max{j |a[j-1]<a[j]},j=2,3,...,n
b) j=max{k |a[i-1]<a[k]},k=1,2,...,n
c) a[i-1]与a[j]互换
d) a[i],a[i+1],...,a[n]逆转,即变成a[n],a[n-1],...,a[i],其它的不变
*/
#include <stdio.h>
int max_compare1(int a[],int n)
{
int i;
for(i=n;i>=1;i--)
if(a[i]>a[i-1])
return i;
return 0;
}
int max_compare2(int a[],int n,int i)
{
int j;
for(j=n;j>=1;j--)
if(a[j]>i)
return j;
return 0;
}
void reverse_(int a[],int i,int n)
{
int j,temp;
for(j=i;j<=(n+i)/2;j++)
{
temp=a[j];
a[j]=a[i+n-j];
a[i+n-j]=temp;
}
}
void print(int a[],int n)
{
int i;
for(i=1;i<=n;i++) printf("%d ",a[i]);
printf("\n");
}
int finish(int a[],int n)
{
int i;
for(i=1;i<=n;i++)
if(a[i]!=n+1-i) return 0;
return 1;
}
main()
{
int a[20],i,j,n,temp,c,d;
scanf("%d",&n);
for(i=0;i<=n;i++) a[i]=i;
while(1)
{ print(a,n);
if(finish(a,n)==1) break;
c=max_compare1(a,n);
d=max_compare2(a,n,a[c-1]);
temp=a[d];
a[d]=a[c-1];
a[c-1]=temp;
reverse_(a,c,n);
}
}


2006-04-20 12:27
daringqq
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2006-5-9
收藏
得分:0 
要是输入到文件应该可以吧,控制台要缓冲会比较慢
2006-05-09 11:13
slovey
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2007-6-16
收藏
得分:0 
四楼的是以空间换时间的吧?
要是输入10的话.要几个小时吧.
还要很快的CPU.
2007-10-30 18:08
卧龙孔明
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:59
帖 子:3872
专家分:684
注 册:2006-10-13
收藏
得分:0 

先计算,然后放在数组里,最后O(1)输出


My Blog: www.aiexp.info
虽然我的路是从这里开始的,但是这里不再是乐土.感谢曾经影响过,引导过,帮助过我的董凯,飞燕,leeco,starwing,Rockcarry,soft_wind等等等等.别了,BCCN.
2007-10-31 12:34
zxc1998
Rank: 1
等 级:新手上路
威 望:1
帖 子:133
专家分:0
注 册:2007-3-21
收藏
得分:0 

我试了一下,当把输出重定向到文件时,把输入和辅助数组的初始化时间排除在外,只计算全排列
10为22秒。但输出文件很大将近80MB。文件部分如下:
0 1 2 3 4 5 6 7 8 9
0 1 2 3 4 5 6 7 9 8
0 1 2 3 4 5 6 8 7 9
.........
9 8 7 6 5 4 3 2 0 1
9 8 7 6 5 4 3 2 1 0

time: 22s.

全排列共3628800行,加上时间的显示共3628802行

2007-10-31 21:47
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
收藏
得分:0 
要说快,那直接把结果保存在文件里,直接把文件输出.
这样当然是最快的了.

如果想看看算法的,不知道我的全排列帖子里的程序要多长时间.

倚天照海花无数,流水高山心自知。
2007-11-01 13:47
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
收藏
得分:0 

倚天照海花无数,流水高山心自知。
2007-11-01 13:48
快速回复:关于全排列
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.054369 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved