排序算法学习笔记 C/C++

排序算法学习,记录之。

1.冒泡排序

最佳情况:T(n) = O(n)
最差情况:T(n) = O(n2)
平均情况:T(n) = O(n2)

int Bubble_Sort(int *array,int len)
{
	if (len == 0) return 0;
	int i, j;
	for (i = 0; i < len; i++)
	{
		for (j = i+1; j < len; j++)
		{
			if (array[i] > array[j])
			{
				int temp;
				temp = array[j];
				array[j] = array[i];
				array[i] = temp;
			}
		}
	}
	return *array;
}

2.选择排序

最佳情况:T(n) = O(n2)
最差情况:T(n) = O(n2)
平均情况:T(n) = O(n2)

int Select_Sort(int *array, int len)
{
	if (len == 0) return 0;
	int i,j;
	for (i = 0; i < len; i++)
	{
		int min = array[i];
		int Index = i;
		for (j = i+1; j < len; j++)
		{
			if (array[j] < min)
			{
				min = array[j];
				Index = j;
			}
		}
		array[Index] = array[i];
		array[i] = min;
	}
	return *array;
}

3.插入排序

最佳情况:T(n) = O(n)
最坏情况:T(n) = O(n2)
平均情况:T(n) = O(n2)

int Insert_Sort(int *array, int len)
{
	if (len == 0) return 0;
	for (int i = 0; i < len - 1; i++)
	{
		int preIndex = i;
		int current = array[i + 1];
		while (preIndex >= 0 && current < array[preIndex])
		{
			array[preIndex + 1] = array[preIndex];
			preIndex--;
		}
		array[preIndex + 1] = current;
	}
	return *array;
	
}

4.希尔排序

最佳情况:T(n) = O(nlog2 n)
最坏情况:T(n) = O(nlog2 n)
平均情况:T(n) =O(nlog2n)

int Shell_Sort(int *array, int len)
{
	if (len == 0) return 0;

	int gap = len / 2;
	while (gap > 0)
	{
		for (int i = 0; i < len - gap; i++)
		{
			int preIndex = i;
			int current = array[i+gap];
			while (preIndex >= 0 && current <  array[preIndex])
			{
				array[preIndex+gap] = array[preIndex];
				preIndex = preIndex - gap;
			}
			array[preIndex+gap] = current;
		}
		gap = gap / 2;
	}
	return *array;
}

5.快速排序

最佳情况:T(n) = O(nlogn)
最差情况:T(n) = O(n2)
平均情况:T(n) = O(nlogn)

//快速排序
int GetIndex(int *arr, int left, int right)
{
	if (left > right) return 0;
	int curent = arr[left];
	while (left < right)
	{
		while (left < right && curent <= arr[right])
			right--;
		arr[left] = arr[right];//挖坑 vec[right]
		while (left < right && curent >= arr[left])
			left++;
		arr[right] = arr[left];//填坑 vec[right]  挖坑 vec[left]
	}
	arr[left] = curent;//填坑 vec[left]
	return left;
}

void Quick_Sort(int *arr,int left,int right)
{
	if (left > right) return;
	if (left < right)
	{
		int index = GetIndex(arr, left, right);
		Quick_Sort(arr, 0, index - 1);
		Quick_Sort(arr, index + 1, right);
	}
}

6.归并排序

最佳情况:T(n) = O(n)
最差情况:T(n) = O(nlogn)
平均情况:T(n) = O(nlogn)

void Merge(int *array, int left, int mid, int right)
{
	int size = right - left + 1;
	//int *array1 = (int *)malloc(size * sizeof(int));
	int *array1 = new int[size];
	memset(array1, 0, size * 4);
	int i = left, j = mid + 1;
	int Index = 0;
	while (i <= mid && j <= right)
	{
		array1[Index++] = array[i] < array[j] ? array[i++] : array[j++];
	}
	while (i <= mid)
	{
		array1[Index++] = array[i++];
	}
	while (j <= right)
	{
		array1[Index++] = array[j++];
	}
	for (int n = 0; n < size; n++)
	{
		array[left++] = array1[n];
	}
	delete array1;

}

void Merge_Sort(int *array, int left,int right)
{
	if (left == right) return;
	int mid = left + ((right - left) / 2);
	
		Merge_Sort(array, left, mid);
		Merge_Sort(array, mid+1, right);
		Merge(array, left, mid, right);
}

7.堆排序

最佳情况:T(n) = O(nlogn)
最差情况:T(n) = O(nlogn)
平均情况:T(n) = O(nlogn)

//堆排序
void heap_Adjust(int *arr, int i, int length)
{
	//int temp = arr[i];
	for(int left = 2 * i + 1; left < length; left = 2 * left + 1)
	{
		int right = left + 1;
		if (right < length && arr[left] < arr[right])//如果右节点大于左节点
		{
			left++;
		}
		if (arr[i] < arr[left])
		{
		//	arr[i] = arr[left];
			swap(arr, i, left);
			i = left;
		}
		else {
			break;
		}
	//	arr[i] = temp;
	}
}
void heap_Sort(int *arr, int length)
{
	if (length == 0) return;
	for (int i = (length / 2) - 1 ; i >= 0; i--)
	{
		heap_Adjust(arr,i,length);
	}
	while (length > 0)
	{
		swap(arr, 0, length-1);
		length--;
		heap_Adjust(arr, 0,length);
	}
}

8.计数排序

最佳情况:T(n) = O(n+k)
最差情况:T(n) = O(n+k)
平均情况:T(n) = O(n+k)

int Count_Sort(int *array,int len)
{
	if (len == 0) return 0;
	int min = array[0];
	int max = array[0];
	for (int i = 1; i < len; i++)
	{
		if (array[i] < min)
		{
			min = array[i];
		}
		if (array[i] > max)
		{
			max = array[i];
		}
	}
	int size = max - min + 1;
	int *array1 = new int[size];
	//int *array1 = (int *)malloc(size * sizeof(int));
	memset(array1, 0, size * 4);

	for (int i = 0; i < len; i++)
	{
		array1[array[i]-min]++;
	}
	int j = 0;
	for (int i = 0; i < size; i++)
	{
		while (array1[i]--)
		{
			array[j++] = i + min;
		}
	}
	return *array;
	delete array1;
}

9.测试案例

int main()
{
	int A[] = { 2, 6, 4, 8, 2, 5, 9,9,10,20 };
		int len = sizeof(A) / sizeof(int);

		//Bubble_Sort(A,len);
		//Select_Sort(A, len);
		//Insert_Sort(A, len);
		//Shell_Sort(A,len);
		//Merge_Sort(A, 0, len-1);
		//Quick_Sort(A,1,len - 1);
		//heap_Sort(A,len-1);
		//Count_Sort(A, len);

		for (int i = 0; i < len; i++)
		{
			printf("%d ", A[i]);
		}
	return 0;
}

以上是排序算法的简单实现,算法原理的理解敬请各位移步如下:
该链接的这位老哥总结的非常详细,还有算法过程的动态图图解,值得珍藏。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 《算法笔记》是由胡凡编写的一本关于算法学习的教材,它最初以C/C++为主要编程语言。这本教材主要面向想要学习算法的初学者,以及希望进一步提升算法能力的人群。 《算法笔记》的内容广泛而且深入,涵盖了很多算法的基础知识和主要思想,如递归、排序、查找、图论、动态规划等。通过学习这本教材,读者可以掌握这些算法的基本原理和实现方法,提高解决实际问题的能力。 该教材有几个特点:首先,它提供了很多例子和习题,帮助读者巩固所学的知识;其次,它介绍了很多常用的数据结构,如数组、链表、栈、队列等,读者可以通过学习这些数据结构更好地理解和应用算法;最后,它还介绍了一些高级主题,如高级数据结构、算法优化等,这些内容对于进一步提升算法水平非常有帮助。 《算法笔记》是一本入门级的教材,因此在阅读时需要一些基本的编程知识和逻辑思维能力。该教材的语言简洁明快,适合作为学习参考书,同时也可以作为算法竞赛的辅助教材。 总而言之,《算法笔记》是一本很好的算法学习教材,它以C/C++为编程语言,全面介绍了算法的基本知识和常用方法,适合想要学习算法的初学者。无论是学术研究还是实际应用,阅读《算法笔记》都能提升算法能力,并为进一步学习和应用算法打下坚实的基础。 ### 回答2: 《算法笔记 胡凡 c/c 快速入门pdf》是一本介绍算法和C/C++编程语言的入门书籍。该书的作者是胡凡,它主要规划了算法的学习路径以及基本的C/C++编程语言。这本书适合初学者快速入门,对于想要系统学习算法和C/C++编程的人来说是一本不错的选择。 这本书的内容非常系统和全面。它以算法和数据结构为基础,包括基本排序、查找、图论等算法的介绍和实践,让读者能够快速掌握这些算法的原理和实现方法。同时,它还介绍了C/C++语言的基础知识和编程技巧,帮助读者理解和运用这些知识。 书中每章都有一些练习题,帮助读者巩固所学的知识。同时,每个章节末尾还提供了一些进阶的题目和参考答案,供读者深入学习和自我检测。这样的设计能够帮助读者更好地理解和掌握所学的内容。 总的来说,《算法笔记 胡凡 c/c 快速入门pdf》是一本很好的算法和C/C++入门书籍。它能够帮助读者快速了解算法和数据结构的基础知识,并学会使用C/C++语言进行编程。无论是对于想要入门算法和C/C++编程的初学者,还是已经有一定基础的读者,这本书都是一个很好的选择。 ### 回答3: 《算法笔记:胡凡C/C++快速入门PDF》是一本很棒的入门算法书籍。这本书主要介绍了常用的数据结构与算法,并通过C/C++语言来实现这些算法。 首先,这本书非常适合算法初学者。它从基础的数据结构开始讲解,如数组、链表、栈和队列,然后逐渐引入更复杂的数据结构,如二叉树、图和堆。此外,书中还介绍了常用的排序和查找算法,如冒泡排序、快速排序、二分查找等。每个算法都配有具体的代码实现和详细的解释,帮助读者理解算法的原理和应用。 其次,这本书的学习资料丰富。书中提供了很多例题和习题,读者可以通过实践来巩固所学的知识。此外,书中还介绍了一些常见的算法优化技巧和设计思路,提供了一些高效解决问题的方法和思考方式。 最后,这本书的编写风格简明易懂。作者通过清晰的语言和简洁的代码,将复杂的算法问题简化为易于理解的部分。不论是对于算法初学者还是对于有一定编程基础的读者,这本书都是一本很好的学习资料。 总而言之,《算法笔记:胡凡C/C++快速入门PDF》是一本很好的入门算法书籍。它适合初学者学习和理解常用的数据结构与算法,通过具体的代码实现和详细的解释帮助读者掌握算法的原理和应用。无论是编程初学者还是有一定基础的读者,都可以从这本书中获得丰富的知识和实践经验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值