C语言图解常见排序算法

C语言图解常见排序算法

1 冒泡排序

​ 冒泡排序是比较常见的一种排序,即便是初学者,也略知一二,啥也不是说了,上图。

在这里插入图片描述

接下来上代码,动手实践一遍才牢靠。

#include<stdio.h>
#include<stdlib.h>
#define Max_array 10



/*交换函数*/
void swap(int *a,int *b)
{
	int temp=*a;
	*a=*b;
	*b=temp;
	return;
}
/*冒泡排序*/
void bubble_sort(int *array)
{
	int i=0,j=0;
	for(;i<Max_array-1;i++)//注意此时是i<Max_array-1而不是i<Max_array
	{
		for(j=0;j<Max_array-i-1;j++)
		{
			if(array[j]>array[j+1])
			{
				swap(&array[j],&array[j+1]);
			}

		}
	}
	return;
}

2 选择排序

同样,上图,理解原理、写代码。

在这里插入图片描述

动手实践一遍才牢靠,一定要自己动手写一遍。

#include<stdio.h>
#include<stdlib.h>
#define Max_array 10

/*交换函数*/
void swap(int *a,int *b)
{
	int temp=*a;
	*a=*b;
	*b=temp;
	return;
}
/*选择排序*/
void select_insort(int *array)
{
	int i=0;
	for(;i<Max_array-1;i++)
	{
		int j=i+1;
		for(;j<Max_array;j++)
		{
			if(array[j]<array[i])
			{
				swap(&array[j],&array[i]);
			}
		}	
	}
	return;
}

3 插入排序

同样,上图,理解原理、写代码。
在这里插入图片描述

再说一遍,一定要自己动手写一遍。

#include<stdio.h>
#include<stdlib.h>
#define Max_array 10
/*插入排序*/
void insert_sort(int *array)
{
	if(array==NULL)
		return;
	int i=0;
	for(i=1;i<Max_array;i++)
	{
		int j=i-1;
		int temp=array[i];//哨兵的作用
		for(;j>=0&&array[j]>=temp;j--)
		{
			array[j+1]=array[j];
		}
		array[j+1]=temp;
	}
	return;
}

4 快速排序

同样,上图,理解原理、写代码。

在这里插入图片描述

很重要,很重要,看完自己写一遍。

#include<stdio.h>
#include<stdlib.h>
#define Max_array 10
/*快速排序*/
void quick_sort(int *array,int low,int high)
{
	if(array==NULL||low>=high)//判断边界条件
		return;
	int left=low,right=high;
	int temp=array[low];//哨兵,这个根据自己个人习惯选择的,不是很固定
	while(left<right)
	{
		while(left<right&&array[right]>=temp)//右边的数大于哨兵,跳过
		{
			right--;
		}
		if(left<right)//右边的数小于哨兵,换位置
		{
			array[left]=array[right];
			left++;

		}
        
		while(left<right&&array[left]<temp)//左边的数小于哨兵,跳过
		{
			left++;
		}
		if(left<right)//左边的数大于哨兵,换位置
		{
			array[right]=array[left];
			right--;
		}
	}
	array[left]=temp;
	quick_sort(array,low,left-1);
	quick_sort(array, left+1,high);
	return;
}

5 归并排序

归并排序主要是分治的思想,理解这个原理很重要,因为他有时候不仅仅在排序上,在其他很多问题上也比较常见,把一个大的问题,分开解决。上图,理解原理、写代码。

在这里插入图片描述

很重要,很重要,写完才是自己的,不要眼高手低。

/*归并排序的具体的实现*/
void merger(int *array,int low,int mid,int high)
{
	int *temp=(int *)malloc(sizeof((high-low)+1)*sizeof(int));

	int left=low,right=mid+1,t=0;
    /*实现分治,把排序的结果写入动态分配空间中*/
	while(left<=mid && right<=high)
	{
		if(array[left]<=array[right])
		{
			temp[t++]=array[left++];
		}
		else
		{
			temp[t++]=array[right++];
		}
	}

	while(left<=mid)
	{
		temp[t++]=array[left++];

	}

	while(right<=high)
	{
		temp[t++]=array[right++];
	}

    /*将动态分配的值写入数组中*/
	for(;low<=high;low++)
	{
		array[low]=temp[t-(high-low)-1];
	}
	free(temp);
	return;
}

/*归并排序*/
void merger_sort(int *array,int low,int high)
{
	if(array==NULL||low>=high)
		return;
	
	int mid=(low+high)/2;
	merger_sort(array, low,mid);//进行递归,便于实现分治
	merger_sort(array, mid+1,high);
	merger(array, low, mid, high);
	
	return;
}
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值