文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

数据结构与算法—常用的排序算法

2024-11-30 15:39

关注

排序算法是计算机科学领域中非常重要的基础算法之一,主要应用于数据处理中,将未排序的数据按照一定规则排列,以便后续的计算和数据分析。目前常用的排序算法有多种,包括冒泡排序、插入排序、选择排序、归并排序、快速排序等。本文将逐一介绍每一种排序算法的具体实现方法、优缺点以及时间复杂度等。

一、冒泡排序

冒泡排序是一种简单易懂的排序算法,它的基本思路是将待排序的元素比较相邻的两个数,如果前面的数大于后面的数,则交换它们的位置。这样一轮比较下来,最大的数就会被移动到数列的末尾。接下来,再对剩下的数列进行相同的操作,直到排序完成。

冒泡排序的具体实现如下:

void bubble_sort(int arr[], int len)
{
int i, j, temp;
for(i = 0; i < len - 1; i++)
{
for(j = len - 1; j > i; j--)
{
if(arr[j] < arr[j - 1])
{
temp = arr[j];
arr[j] = arr[j - 1];
arr[j - 1] = temp;
}
}
}
}

冒泡排序的优点是实现简单易懂,缺点是时间复杂度较高,为O(n^2),在数据量较大的情况下比较耗时,不适合处理大规模数据。

二、插入排序

插入排序是一种直观、简单的排序算法,它的基本思路是将待排序的元素逐个插入到已排好序的序列中,以保证插入后的序列仍然有序。插入排序分为直接插入排序和希尔排序两种。

1、直接插入排序

直接插入排序的具体实现如下:

void insert_sort(int arr[], int len)
{
int i, j, temp;
for(i = 1; i < len; i++)
{
temp = arr[i];
j = i - 1;
while(j >= 0 && arr[j] > temp)
{
arr[j + 1] = arr[j];
j--;
}
arr[j + 1] = temp;
}
}

直接插入排序的优点是实现简单,对于数据量较小的情况下性能较好。缺点是时间复杂度为O(n^2),同样不适合处理大规模数据。

2、希尔排序

希尔排序是插入排序的一种改进算法,它的基本思路是通过将序列分成若干个子序列来进行插入排序,使得整个序列基本有序,然后再对整个序列进行插入排序。希尔排序具有时间复杂度为O(n^(3/2))的优点,在实际应用中性能较好。

希尔排序的具体实现如下:

void shell_sort(int arr[], int len)
{
int i, j, gap, temp;
for(gap = len / 2; gap > 0; gap /= 2)
{
for(i = gap; i < len; i++)
{
temp = arr[i];
j = i - gap;
while(j >= 0 && arr[j] > temp)
{
arr[j + gap] = arr[j];
j -= gap;
}
arr[j + gap] = temp;
}
}
}

三、选择排序

选择排序是一种简单直观的排序算法,它的基本思路是将待排序的序列分成已排序和未排序两部分,从未排序的部分中找到最小的元素,将其放到已排序部分的末尾。接着再从未排序部分中继续寻找最小的元素,重复上述过程,直到最终排序完成。

选择排序的具体实现如下:

void select_sort(int arr[], int len)
{
int i, j, k, temp;
for(i = 0; i < len - 1; i++)
{
k = i;
for(j = i + 1; j < len; j++)
{
if(arr[j] < arr[k])
{
k = j;
}
}
if(k != i)
{
temp = arr[i];
arr[i] = arr[k];
arr[k] = temp;
}
}
}

选择排序的优点是实现简单直观,缺点是时间复杂度较高,为O(n^2),同样不适合处理大规模数据。

四、归并排序

归并排序是一种非常高效的排序算法,它的基本思路是分治法,将待排序的序列分成若干个单独的子序列,分别对每个子序列进行排序,最后将排序好的子序列合并,形成一个排好序的序列。

归并排序的具体实现如下:

void merge_sort(int arr[], int len)
{
int *a = arr;
int *b = (int*)malloc(len*sizeof(int));
int seg, start;
for(seg = 1; seg < len; seg += seg)
{
for(start = 0; start < len; start += seg+seg)
{
int low = start, mid = min(start+seg, len), high = min(start+seg+seg, len);
int k = low;
int start1 = low, end1 = mid;
int start2 = mid, end2 = high;
while(start1 < end1 && start2 < end2)
{
b[k++] = a[start1] < a[start2] ? a[start1++] : a[start2++];
}
while(start1 < end1) {
b[k++] = a[start1++];
}
while(start2 < end2)
{
b[k++] = a[start2++];
}
}
int *temp = a;
a = b;
b = temp;
}
if(a != arr)
{
int i;
for(i = 0; i < len; i++)
{
b[i] = a[i];
}
b = a;
}
free(b);
}

归并排序的优点是具有时间复杂度为O(nlogn)的优点,适合处理大规模的数据。缺点是空间开销较大,需要额外的内存空间进行归并操作。

五、快速排序

快速排序是一种高效的排序算法,它的基本思路是分治法,选取一个中间的基准值,将序列分成两个子序列,一边小于基准值,一边大于基准值,再对这两个子序列进行递归操作,直到排序完成。

快速排序的具体实现如下:

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

快速排序的优点是具有时间复杂度为O(nlogn)的优点,适合处理大规模的数据。缺点是对于特殊情况下容易出现性能退化,需要进行优化。

小结

各种排序算法各有优缺点,在实际应用中需要根据具体场景选择适合的排序算法,以求得最佳的性能和效率。

来源:今日头条内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯