溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

幾種簡(jiǎn)單的排序算法實(shí)現(xiàn)

發(fā)布時(shí)間:2020-08-14 19:16:48 來(lái)源:網(wǎng)絡(luò) 閱讀:410 作者:陳國(guó)成 欄目:編程語(yǔ)言

幾種簡(jiǎn)單的排序算法實(shí)現(xiàn)

冒泡排序

void bubbleSort(int *pData,int count)
{
	for (int i = 1;i<count;i++)
	{
		for (int j = count-1;j>=i;j--)
		{
			if (pData[j]<pData[j-1])
			{
				int iTmp = pData[j];
				pData[j] = pData[j-1];
				pData[j-1] = iTmp;
			}
		}
	}
}

選擇排序

void selectSort(int* list,int count)
{
	int min,i,j;
	for (i = 0;i <count;i++)
	{
		min = i;
		for (j=i+1;j<count;j++)
		{
			if(list[i]>list[j])
				min = j;
		}
		if(min != i)
			swap(list[i],list[min]);
	}
}

折半插入排序算法

void binary_insertion_sort(int array[], int n)   
{  
	int i, j, temp, m, low, high;  
	for (i = 1; i < n; i++)  
	{  
		temp = array[i];  
		low = 0; high = i-1;  
		//5,36,24,10,6,12
		while (low <= high)  
		{  
			m = (low +high) / 2;  
			if(array[m] > temp)  
				high = m-1;  
			else  
				low = m+1;  
		}  
		for (j = i-1; j>=high+1; j--)  
			array[j+1] = array[j];  
		array[j+1] = temp; 
		cout<<endl;
	}  
}

插入排序

void InsertSort(int array[],int n)  
{
	for(int i=1;i<n;i++)  
	{
		for(int j=i;j>0;j--)
		{
			if(array[j]>array[j-1])  
				swap(array[j],array[j-1]);  
			else  
				break;  
		}  
	}  
}

快速排序

void quick_sort(int s[], int left, int right)
{
	if(left<right)
		return;
	int i = left,j=right,temp = s[left],t;
	while(i!=j)
	{
		while(i<j && temp <= s[j])
			j--;
		while(i<j && temp >= s[i])
			i--;
		if (i<j)
		{
			t = s[i];
			s[i]=s[j];
			s[j]=t;
		}
	}
	s[left] = s[i];
	s[i]=temp;
	quick_sort(s,left,i-1);
	quick_sort(s,i+1,right);
}


向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI