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

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

排序算法之選擇排序

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

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

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

選擇排序代碼如下:

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

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 兰溪市| 赤城县| 从化市| 万山特区| 观塘区| 若尔盖县| 巴林右旗| 海原县| 河津市| 彰武县| 南皮县| 海晏县| 怀集县| 杭锦旗| 皋兰县| 沾化县| 同德县| 四子王旗| 东港市| 武隆县| 新巴尔虎右旗| 宜兰县| 凌云县| 永德县| 名山县| 长治市| 宁乡县| 白水县| 广饶县| 石渠县| 紫金县| 江阴市| 若尔盖县| 沂南县| 永和县| 岳普湖县| 汾西县| 新泰市| 福安市| 延寿县| 平定县|