国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

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

排序算法之選擇排序

2019-11-11 06:00:44
字體:
來源:轉載
供稿:網友

選擇排序核心思想 跟 冒泡排序差不多。

冒泡排序做得比較多無用功,而選擇排序相對較少。

選擇排序代碼如下:

#include<stdio.h>void swap(int *a,int *b){	int t;	t = *a;	*a = *b;	*b = t;}int main(){	int a[]={5,2,3,1,4};	int i,j,min,len;		len = sizeof(a)/sizeof(int);		/*-----主要語句-----*/	for(i=0;i<len;i++)	{		min = i;		for(j=i+1;j<len;j++)			if(a[min]>a[j])				min = j;				if(min!=i)			swap(&a[i],&a[min]);	}	/*---------------*/ 		for(i=0;i<len;i++)		PRintf("%d,",a[i]);		return 0;} 打印結果:1,2,3,4,5

由上圖可知道,選擇排序在第二層for循環中,是用 min 來記錄下較小數值的下標,一輪循環過后,min自然是最小的數值的下標,然后再做數值交換。

所以在二層for循環,一輪循環,才會做一次數值交換,而不像冒泡排序,只要是檢測到比最小的還小的數值就馬上做數值交換,而不等到整個循環結束(你怎么知道下一個會不會更小呢?)

因此冒泡排序是十分慢的算法


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 南江县| 舟曲县| 加查县| 凭祥市| 灵宝市| 芜湖市| 玉环县| 泰兴市| 个旧市| 丁青县| 耿马| 靖江市| 峨山| 陕西省| 安福县| 咸宁市| 监利县| 民和| 海晏县| 峨边| 宁明县| 曲水县| 沙湾县| 招远市| 宜州市| 隆昌县| 报价| 定结县| 涪陵区| 江北区| 工布江达县| 梁河县| 太白县| 虎林市| 凌源市| 兴业县| 高雄市| 阿拉善盟| 锦屏县| 托克逊县| 宁城县|