亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? sort.bak

?? 測試各種排序算法,使用VC.NET進(jìn)行開發(fā)
?? BAK
字號:


//排序算法
//by lordor 2005.08.20
#include "stdafx.h"

//數(shù)據(jù)結(jié)構(gòu)
const int maxsize=100;	//排序表容量,假設(shè)為100
typedef int datatype;	//假設(shè)關(guān)鍵字為int
typedef struct { 
	datatype key;		//關(guān)鍵字域
//	othertype other;		//其它域
} rectype;				//記錄類型
typedef rectype list[maxsize+1];
//排序表類型,0號單元不用(或作它用,如“監(jiān)視哨”)


//直接插入排序
void InsertSort(list R,int n) { //有監(jiān)視哨
	int i,j;
	 for(i=2;i<=n;i++) { //進(jìn)行n-1次插入
		 if(R[i].key>=R[i-1].key) continue;
		 R[0]=R[i];        //R[0]是監(jiān)視哨
		 j=i-1;
		 do {              //順序比較和移動
			 R[j+1]=R[j];j--;
		 } while(R[0].key<R[j].key); 
		 R[j+1]=R[0];      //插入R[i]
	 }
}


//希爾排序
void ShellInsert(list R,int n,int h){
	//一趟插入排序,h為本趟增量
	int i,j,k;
	for(i=1;i<=h;i++)		//i為組號
		for(j=i+h;j<=n;j+=h) {//每組從第2個(gè)記錄開始插入
			if(R[j].key>=R[j-h].key) continue;
			R[0]=R[j];	//R[0]保存待插記錄,但不是監(jiān)視哨
			k=j-h;		//待插記錄的前一個(gè)記錄
			do{		//查找插入位置
				R[k+h]=R[k];k=k-h;//后移記錄,繼續(xù)向前搜索
			} while(k>0 && R[0].key<R[k].key);
			R[k+h]=R[0];	//插入R[j]
		}
}

//調(diào)用希爾
void ShellSort(list R,int n,int d[],int t) {
	//d[]為增量序列,t為增量序列長度
	int i;
	for(i=0;i<t;i++)		    //各趟插入排序
		ShellInsert(R,n,d[i]);
}


//冒泡排序
void BubbleSort(list R,int n) {//上升法冒泡排序
	int i,j,flag;
	for(i=1;i<=n-1;i++) {		//做n-1趟掃描
		flag=0;				//置未交換標(biāo)志
		for(j=n;j>=i+1;j++)		//從下向上掃描
			if(R[j].key<R[j-1].key) {//交換記錄
				flag=1;
				R[0]=R[j];R[j]=R[j-1];R[j-1]=R[0];
				//交換,R[0]作輔助量 
			}
			if(!flag) break;	  //本趟未交換過,排序結(jié)束
	}
}



//快遞排序
int Partition(list R,int p,int q) {	
	//對無序區(qū)R[p]到R[q]劃分,返回劃分后基準(zhǔn)的位置
	int i,j;
	i=p;  j=q;   R[0]=R[i];
	//R[0]作輔助量,存基準(zhǔn)(無序區(qū)第一個(gè)記錄)
	while(i<j) {
		while(R[j].key>=R[0].key && i<j) j--;
		//從右向左掃描
		if(i<j) {R[i]=R[j];i++;}	//交換R[i]和R[j]
		while(R[i].key<=R[0].key && i<j) i++;
		//從左向右掃描
		if(i<j) {R[j]=R[i];j--;}	//交換R[i]和R[j]
	}
	R[i]=R[0];			//將基準(zhǔn)移到最后位置
	return i;
}

//快速排序
void QuickSort(list R,int s,int t) {
	//對R[s]到R[t]快速排序
	int i;
	if(s>=t) return;	//只有一個(gè)記錄或無記錄無需排序
	i=Partition(R,s,t);	//對R[s]到R[t]做劃分
	QuickSort(R,s,i-1);	//遞歸處理左區(qū)間
	QuickSort(R,i+1,t);	//遞歸處理右區(qū)間
}



//直接選擇排序
void SelectSort(list R,int n) {
	int i,j,k;
	for(i=1;i<=n-1;i++) {	//n-1趟排序
		k=i;
		for(j=i+1;j<=n;j++)	//無序區(qū)中找最小R[k]
			if(R[j].key<R[k].key) k=j;
		if(k!=i) {R[0]=R[i];R[i]=R[k];R[k]=R[0];}
		          //交換R[i]和R[k],R[0]作輔助
	}
}


//堆排序

void Sift(list R,int p,int q) {
	//篩選,范圍R[p]~R[q],非遞歸
	int i,j;
	R[0]=R[p];		//R[0]輔助量,保存原根結(jié)點(diǎn)
	i=p;			//i指向待調(diào)整點(diǎn)
	j=2*i;			//j指向R[i]的左孩子
	while(j<=q) {    //無左孩子,必葉子,結(jié)束
		if(j<q && R[j].key<R[j+1].key) j++;
		            //j指向R[i]的右孩子
		if(R[0].key>R[j].key) break;	
		            //根>孩子,已堆,調(diào)整結(jié)束
		R[i]=R[j];	//將R[j]換到雙親位置上
		i=j;			//修改當(dāng)前被調(diào)整結(jié)點(diǎn)
		j=2*i;		//j指向R[i]的左孩子
	}
	R[i]=R[0];		//原根結(jié)點(diǎn)放入正確位置
}

void Sift2(list R,int p,int q) {
	 //篩選,范圍R[p]~R[q],遞歸
	int i,j;
	if(p>=q) return;	//只有一個(gè)元素或無元素
	i=p;			//i指向待調(diào)整點(diǎn)
	j=2*i; 			//j指向R[i]的左孩子
	if(j<q && R[j].key<R[j+1].key) j++;
	            //j指向R[i]的右孩子
	if(R[i].key>R[j].key) return;
	            //待調(diào)點(diǎn)已最大,不調(diào)
	R[0]=R[j];R[j]=R[i];R[i]=R[0];
	            //交換R[j]和R[i],R[0]作輔助
	Sift2(R,j,q);	//遞歸
}



void HeapSort(list R,int n) {
	//對R[1]到R[n]進(jìn)行堆排序
	int i;
	for(i=n/2;i>=1;i--) Sift(R,i,n);	//建初始堆
	for(i=n;i>=2;i--) {//進(jìn)行n-1趟堆排序
		R[0]=R[1];R[1]=R[i];R[i]=R[0];
		          //堆頂和當(dāng)前堆底交換,R[0]作輔助量
		Sift(R,1,i-1); //R[1]到R[i-1]重建成新堆
	}
}




//歸并排序
void Merge(list R,list R1,int low,int mid,int high)
{
	//合并R[low]~R[mid]、R[mid+1]~R[high],結(jié)果在R1中
	int i,j,k;
	i=low;j=mid+1;k=low; 
	while(i<=mid && j<=high)
		if(R[i].key<=R[j].key) R1[k++]=R[i++]; //小者
		else R1[k++]=R[j++];
		while(i<=mid) R1[k++]=R[i++]; //復(fù)制左子表剩余
		while(j<=high) R1[k++]=R[j++]; //復(fù)制右子表剩余
}



void MergePass(list R,list R1,int n,int len) {
	//對R做一趟歸并,結(jié)果在R1中
	int i,j;
	i=1;			//i指向第一對子表的起始點(diǎn)
	while(i+2*len-1<=n) {	//歸并長度為len的兩個(gè)子表
		Merge(R,R1,i,i+len-1,i+2*len-1);
		i=i+2*len;	//i指向下一對子表起始點(diǎn)
	}
	if(i+len-1<n)	//剩兩子表,一個(gè)長度小于len
		Merge(R,R1,i,i+len-1,n); 
	else			//子表個(gè)數(shù)為奇數(shù),剩一段
		for(j=i;j<=n;j++)//將最后一個(gè)子表復(fù)制到R1中
			R1[j]=R[j];
}

void MergeSort(list R,list R1,int n) {
	 //對R二路歸并排序,結(jié)果在R中(非遞歸)
	int len;
	len=1;
	while(len<n) {
		MergePass(R,R1,n,len);len=len*2;
		//一趟歸并,結(jié)果在R1中
		MergePass(R1,R,n,len);len=len*2;
		//再次歸并,結(jié)果在R中
	}
}



















?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产日韩欧美电影| 日本欧美韩国一区三区| 丝袜美腿成人在线| 色综合欧美在线| 91精品久久久久久久久99蜜臂| 国产欧美日韩久久| 裸体健美xxxx欧美裸体表演| 99精品视频在线播放观看| 精品少妇一区二区三区日产乱码 | 丝袜亚洲另类欧美综合| 国产剧情一区在线| 91麻豆精品国产| 亚洲色图欧美激情| 国产精品77777| 精品国产乱码久久久久久久久| 一区二区视频免费在线观看| 成人黄色在线视频| 国产亚洲成aⅴ人片在线观看| 视频一区二区国产| 欧美性大战久久| 亚洲欧洲日产国产综合网| 国产一区999| 亚洲精品一线二线三线无人区| 性欧美疯狂xxxxbbbb| 欧美性色黄大片| 亚洲美女在线国产| 99久久精品国产毛片| 国产欧美日韩激情| 国产.欧美.日韩| 久久久亚洲综合| 国产乱对白刺激视频不卡 | 在线看日韩精品电影| 中文在线资源观看网站视频免费不卡| 九色综合狠狠综合久久| 日韩美女在线视频| 久久99在线观看| 欧美哺乳videos| 精品一区二区三区不卡| 精品国偷自产国产一区| 激情伊人五月天久久综合| 欧美成人福利视频| 国产一区二区三区久久久| 久久久久久免费| 国产v综合v亚洲欧| 日韩一区有码在线| 日本高清视频一区二区| 亚洲综合无码一区二区| 欧美精品一级二级| 久久成人免费日本黄色| 伊人一区二区三区| 欧美三级电影在线观看| 日本欧美韩国一区三区| 久久亚洲二区三区| av日韩在线网站| 亚洲综合自拍偷拍| 日韩一区二区三区高清免费看看| 久久国产精品99精品国产| 国产色91在线| 色哟哟一区二区三区| 婷婷成人综合网| 久久久久国产精品麻豆ai换脸| 懂色中文一区二区在线播放| 亚洲黄色在线视频| 欧美一二三在线| 懂色一区二区三区免费观看| 亚洲已满18点击进入久久| 日韩一区二区三区三四区视频在线观看| 激情综合亚洲精品| 亚洲欧美乱综合| 日韩一级二级三级精品视频| 国产麻豆视频一区| 亚洲一卡二卡三卡四卡| 欧美精品一区二区三区蜜臀| 91首页免费视频| 同产精品九九九| 国产精品天美传媒沈樵| 欧美日韩国产不卡| 成人免费毛片片v| 日韩精品色哟哟| 自拍偷自拍亚洲精品播放| 欧美一区二区视频观看视频 | 99久久99久久久精品齐齐| 午夜精品久久久久久久99水蜜桃| 久久久久久久久久久电影| 欧美午夜在线一二页| 国产成人综合在线播放| 日韩中文欧美在线| 亚洲另类春色国产| 国产日韩av一区二区| 3d动漫精品啪啪1区2区免费 | 天堂va蜜桃一区二区三区 | 国产 欧美在线| 日韩高清在线观看| 一区二区三区在线看| 国产亚洲精品aa午夜观看| 777午夜精品免费视频| 色综合天天综合狠狠| 欧美人狂配大交3d怪物一区 | 精品捆绑美女sm三区| 欧美性猛交xxxx乱大交退制版 | 国产亚洲欧美在线| 日韩一区二区三区免费观看| 精品视频在线看| 91免费看`日韩一区二区| 顶级嫩模精品视频在线看| 久久99热这里只有精品| 日韩成人av影视| 午夜精品福利一区二区三区av | 国产女主播视频一区二区| 日韩久久久久久| 在线观看中文字幕不卡| 91毛片在线观看| 成人av电影免费在线播放| 国产成人精品综合在线观看| 国内精品不卡在线| 久久99久久99小草精品免视看| 午夜久久久久久| 午夜欧美电影在线观看| 视频一区在线视频| 日韩中文字幕区一区有砖一区| 亚洲激情五月婷婷| 1000精品久久久久久久久| 亚洲视频资源在线| 国产精品久久精品日日| 中文字幕一区二区三区不卡在线 | 午夜精品一区二区三区三上悠亚| 国产乱人伦偷精品视频不卡| 久久99热狠狠色一区二区| 蜜臀久久99精品久久久画质超高清 | 久久综合丝袜日本网| 久久久久久久综合狠狠综合| 国产欧美视频一区二区| 中文字幕不卡三区| 亚洲另类在线视频| 亚洲午夜一二三区视频| 日本sm残虐另类| 国产自产2019最新不卡| 大胆亚洲人体视频| 日本韩国精品一区二区在线观看| 欧美日韩国产中文| 欧美成人三级在线| 国产精品久久网站| 亚洲一区二区三区中文字幕 | 日韩欧美第一区| 国产日韩精品一区二区三区在线| 国产精品国产三级国产普通话蜜臀| 亚洲人成精品久久久久久| 亚洲国产成人高清精品| 久久99精品一区二区三区三区| 成人自拍视频在线观看| 91国偷自产一区二区使用方法| 欧美一区二区三区在线电影| 久久久久久**毛片大全| 亚洲伊人伊色伊影伊综合网 | 日韩精品一级中文字幕精品视频免费观看 | 亚洲欧美电影一区二区| 日韩av电影免费观看高清完整版在线观看 | av在线播放成人| 欧美精品免费视频| 石原莉奈在线亚洲二区| 韩国午夜理伦三级不卡影院| 91色视频在线| 精品国产一区二区三区久久久蜜月| 亚洲欧洲av在线| 蜜臀91精品一区二区三区| 成人免费视频一区二区| 91精品国产欧美日韩| 国产精品麻豆视频| 久久精品二区亚洲w码| 色综合天天狠狠| 久久精品一区二区三区不卡| 午夜视频一区二区| 成+人+亚洲+综合天堂| 日韩精品在线一区| 亚洲成a人v欧美综合天堂下载 | 久久久欧美精品sm网站| 亚洲一区二区三区四区的| 成人手机在线视频| 精品久久久久久亚洲综合网| 亚洲综合自拍偷拍| 99久久婷婷国产综合精品| www激情久久| 欧美aaa在线| 欧美日韩一区二区三区视频| 国产精品理论在线观看| 国产精品伊人色| 日韩一区和二区| 午夜视频在线观看一区二区 | 色综合久久中文综合久久97| 久久青草国产手机看片福利盒子| 日本欧美一区二区| 欧美精品一二三区| 无码av中文一区二区三区桃花岛| 色成人在线视频| 亚洲人成伊人成综合网小说| jiyouzz国产精品久久| 国产视频亚洲色图| 国产成人免费在线视频| 亚洲一区二区在线免费观看视频| 成人免费毛片片v|