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

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

排序算法之選擇排序

2019-11-11 04:32:49
字體:
來源:轉載
供稿:網友

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

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

選擇排序代碼如下:

#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循環,一輪循環,才會做一次數值交換,而不像冒泡排序,只要是檢測到比最小的還小的數值就馬上做數值交換,而不等到整個循環結束(你怎么知道下一個會不會更小呢?)

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 灵台县| 孝感市| 长治县| 合川市| 香港| 长治市| 威信县| 青铜峡市| 若羌县| 乌恰县| 科技| 和田市| 公安县| 客服| 双城市| 砚山县| 凉城县| 郯城县| 阜新市| 红桥区| 易门县| 咸丰县| 微山县| 梨树县| 尉犁县| 晋中市| 河源市| 张北县| 阜新市| 石楼县| 宁波市| 济南市| 哈密市| 太保市| 高阳县| 彭泽县| 富蕴县| 揭西县| 自贡市| 清水河县| 内黄县|