亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

一個比較好的全排列算法(C語言)

2019-09-10 09:07:14
字體:
來源:轉載
供稿:網友

 

全排列算法

我有一個比較好的全排列算法,我驗證了3、4、5的結果是正確的。

程序中沒有使用遞歸,只是幾個循環,速度還令人滿意。
在C466A,Win2000的機器上,進行8個數字的全排列,結果不顯示,重定向到一個文本文件中,耗時不到一秒鐘

。9個數字的全排列耗時6秒種。10個數字的全排列55秒種。(以上都不顯示結果,均重定向到一個文本文件)

11個數字的全排列(不顯示結果,在原程序中不定義ISPRINT)耗時大約16秒鐘。

歡迎各位指點

算法為:用兩個數組,一個數組存放當前結果,第二個數組是每一個數是否已經使用的標志。比如對10個數進

行全排列,第一個結果是:0 1 2 3 4 5 6 7 8 9。
然后把每一個數的使用標志均置為1。
然后開始主循環:
   先打印當前的結果。
   在前一個得到的結果中,從后往前找第一個由小到大排列的數。每找一次均置當前位上的數字的使用標志

為0,然后找第一個比這個數大但是沒有使用過的數。
比如前一個結果是:4 1 9 7 8 2 5 0 6 3,那么從后往前第一個由小到大排列的數是0,第一個比0大但是沒有

使用過的數是3(因為比0大的數字里只有6和3)。最后由小到大依次打印剩余沒有使用過的數字。所以下一個

結果是4 1 9 7 8 2 5 3 0 6。

源程序為(在BC++3.0下編譯成功):


#include<stdio.h>/*這兩個庫函數是習慣性的加上去的^_^。*/
#include<stdlib.h>

#define ISPRINT/*是否打印結果的標志*/
#define MAX 200/*最大的數*/

unsigned int *_NUM;/*用于存放一條結果的數組指針*/
char *_NUMFLAG;/*用于存放是否已經使用的標志*/

#define NUM(j) (*(_NUM+(j)))/*第j位的數字*/
#define NUMFLAG(j) (*(_NUMFLAG+(j)))/*數字j是否已經使用的標志,0為沒有使用,1為已經使用*/
#define NUMUSE(j) (*(_NUMFLAG+(*(_NUM+(j)))))/*第j位上的數字是否已經使用的標志,0為沒有使用,1為已

經使用*/

void main()
{
unsigned int number,j;
int i;
printf("Input number=");scanf("%u",&number);
if((number>=MAX)||(number<=1)){puts("輸入數據錯誤。");exit(-1);}

/*初始化內存和第一個結果*/
_NUM=(unsigned int*)malloc(sizeof(unsigned int)*number);
if(!_NUM){puts("分配給_NUM出現內存不足");exit(-1);}
_NUMFLAG=(char*)malloc(sizeof(char)*number);
if(!_NUMFLAG){puts("分配給_NUMFLAG出現內存不足");exit(-1);}

for(i=0;i<number;i++)NUM(i)=i,NUMFLAG(i)=1;/*初始化第一條結果和使用標志*/

do{/*主循環*/
 
 #ifdef ISPRINT/*打印結果*/
 for(j=0;j<number;j++)printf("%d ",NUM(j));/*打印一條結果。*/
 puts("");/*并換行*/
 #endif  

 NUMUSE(number-1)=0;//置最后一位數字的使用標志為0.

 /*在前一個結果中從后往前尋找第一個從小到大排列的數,并存放到變量j中*/
 for(i=number-2;i>=0;i--){
  NUMUSE(i)=0;
  if(NUM(i)<NUM(i+1))break;
 }

 if(i<0)break;/*從這里退出主循環.*/

 for(j=NUM(i)+1;j<number;j++){
  if(!NUMFLAG(j))break;
 }

 NUMFLAG(j)=1;
 NUM(i)=j;

 for(j=0,i++;i<number;j++)
  if(!NUMFLAG(j))NUM(i++)=j,NUMFLAG(j)=1;
}while(1);
/*釋放內存*/
free(_NUM);
free(_NUMFLAG);
}

 

/*程序結束*/

當然了這個程序的速度并不是最快的,程序中還有很大的優化余地,還可以減少一些循環,或者采用其他更好的算法。

下載源程序http://263.csdn.net/FileBBS/files/2001_8/T_387_1.zip

 

上一篇:Foo 的辭源

下一篇:Effective C++ 2e Item43

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品视频资源| 国产精品igao视频| 98精品国产高清在线xxxx天堂| 久久91精品国产91久久跳| 精品亚洲va在线va天堂资源站| 日韩av电影手机在线| 欧美性xxxx极品hd满灌| 久久人体大胆视频| 97视频在线观看亚洲| 91精品国产自产在线老师啪| 日韩中文在线中文网在线观看| 欧美成人精品不卡视频在线观看| 久久久久国产视频| 国产精品永久免费| 97精品在线观看| 亚洲精品视频免费在线观看| 色伦专区97中文字幕| 国产精品第七十二页| 日韩精品在线免费观看视频| 992tv成人免费视频| 中文字幕一区二区三区电影| 伊人久久久久久久久久| 国产精品成人国产乱一区| 91超碰caoporn97人人| 久久久久久一区二区三区| 国产精品一区二区三| 日韩免费观看在线观看| 亚洲欧美中文日韩在线v日本| 亚洲天堂男人天堂| 国产在线拍揄自揄视频不卡99| 欧美在线一区二区视频| 97av在线视频免费播放| 97在线观看免费高清| 成人午夜黄色影院| 伊人伊成久久人综合网站| 综合网日日天干夜夜久久| 国产91精品青草社区| 欧美日韩国产激情| 国产精品美女久久| 久久综合久中文字幕青草| 亚洲一二在线观看| 亚洲精品欧美一区二区三区| 欧美自拍视频在线观看| 久久久精品日本| 成人免费网站在线| 91国产美女在线观看| 欧美日韩国产中文字幕| 欧美极品在线播放| 中文日韩在线视频| 中文字幕一精品亚洲无线一区| 中日韩美女免费视频网址在线观看| 精品日本美女福利在线观看| 欧美大片免费观看在线观看网站推荐| 国内免费精品永久在线视频| 国产精品久久久久久久av大片| 亚洲美女在线视频| 亚洲二区在线播放视频| 91成人精品网站| 欧美精品一二区| 麻豆国产va免费精品高清在线| 欧美激情综合色| 尤物tv国产一区| 欧美电影免费观看高清| 国产精品白嫩美女在线观看| 亚洲色图国产精品| 欧美尺度大的性做爰视频| 亚洲精品一区在线观看香蕉| 91在线高清视频| 国产精品自产拍在线观看中文| 久久夜精品va视频免费观看| 中文字幕精品影院| 久久久久久久香蕉网| 欧美在线亚洲一区| 日韩成人在线播放| 久久激情视频久久| 欧美最猛性xxxx| 疯狂做受xxxx高潮欧美日本| 亚洲国产精彩中文乱码av在线播放| 日韩av中文在线| 欧美日韩国产丝袜美女| 日韩中文在线不卡| 国产精品久久久久久久9999| 日韩欧美国产高清91| 欧美日韩亚洲精品内裤| 中文字幕av日韩| 欧美成人精品激情在线观看| 91九色国产在线| 日本精品一区二区三区在线播放视频| 中文字幕日韩欧美| 亚洲成人免费网站| 欧美在线视频在线播放完整版免费观看| 九九久久综合网站| 中文字幕欧美在线| 日韩在线免费av| 亚洲精品99999| 精品国产视频在线| 欧美精品久久久久久久| 韩日欧美一区二区| 中文字幕久久久| 在线看国产精品| 欧美在线精品免播放器视频| 久久亚洲国产精品成人av秋霞| 爽爽爽爽爽爽爽成人免费观看| 日韩欧美主播在线| 亚洲人成电影网站色| 亚洲国产精品人久久电影| 国产性猛交xxxx免费看久久| 黑人巨大精品欧美一区二区一视频| 91精品国产免费久久久久久| 日本高清久久天堂| 国产精品免费一区豆花| 亚洲欧洲视频在线| 久久99久国产精品黄毛片入口| 亚洲人成电影在线| 亚洲人永久免费| 中文字幕亚洲一区在线观看| 亚洲色图综合久久| 亚洲影视中文字幕| 91sao在线观看国产| 日韩免费中文字幕| 国产精品免费视频xxxx| 欧美国产日韩一区二区在线观看| 久久国产精品影视| 久久久国产精彩视频美女艺术照福利| 最近更新的2019中文字幕| 亚洲日韩欧美视频| 国产精品亚洲一区二区三区| 中文字幕亚洲天堂| 精品久久久国产精品999| 国自产精品手机在线观看视频| 亚洲欧美中文日韩v在线观看| 国产综合色香蕉精品| 欧美极品在线播放| 久久久www成人免费精品张筱雨| 国产精品女人网站| 久久久伊人欧美| 最新69国产成人精品视频免费| 国产精品一区av| 中文字幕九色91在线| 国产日韩在线播放| 国产日韩在线免费| 国产精品成人观看视频国产奇米| 亚洲精品小视频在线观看| 日韩av免费看| 色噜噜狠狠狠综合曰曰曰88av| 精品五月天久久| 中文字幕亚洲自拍| 亚洲成av人乱码色午夜| 欧美高清性猛交| 国外日韩电影在线观看| 日韩中文字幕精品| 国产97在线视频| 中文字幕精品网| 亚洲第一中文字幕| 国内偷自视频区视频综合| 亚洲免费高清视频| 97在线视频精品| 国产精品揄拍500视频| 97精品欧美一区二区三区| 国产成人拍精品视频午夜网站| 91色精品视频在线| 中文字幕日韩欧美精品在线观看| 久久免费视频网| 欧美一区二三区|