国产成人免费观看视频_亚洲国产激情_www.91视频com_www.久久_91视频全集_亚洲综合在

大学生新闻网,大学生新闻发布平台
大学生新闻网
大学生新闻大学生活校园文学大学生村官
社会实践活动社会实践经历社会实践报告社会实践总结社会实践心得
全国排名校友会版软科排名分类排名本科排名一本排名二本排名专科排名学校地址
求职简历职场法则面试技巧职场故事求职招聘大学生就业
英语学习计算机学习电气工程机械工程经济管理建筑设计财务会计
申请书证明书检讨书自荐信演讲稿心得体会调查报告读后感求职信推荐信其它范文

C语言归并排序算法

用归并排序法对一组数据由小到大进行排序,数据分别为 695、458、362、789、12、 15、163、23、2、986。

实现过程:
(1) 自定义函数 merge(),实现一次归并排序。
(2) 自定义函数 merge_sort(),实现归并排序。
(3) 程序代码如下:

#include <stdio.h>
int merge(int r[],int s[],int x1,int x2,int x3)    //自定义实现一次归并样序的函数
{
    int i,j,k;
    i=x1;    //第一部分的开始位置
    j=x2+1;  //第二部分的开始位置
    k=x1;
    while((i<=x2)&&(j<=x3))    //当i和j都在两个要合并的部分中时
        if(r[i]<=r[j])    //筛选两部分中较小的元素放到数组s中
        {
            s[k] = r[i];
            i++;
            k++;
        }
        else
        {
            s[k]=r[j];
            j++;
            k++;
        }
        while(i<=x2)    //将x1〜x2范围内未比较的数顺次加到数组r中
            s[k++]=r[i++];
        while(j<=x3) //将x2+l〜x3范围内未比较的数顺次加到数组r中
            s[k++]=r[j++];
    return 0;
}
 
int merge_sort(int r[],int s[],int m,int n)
{
    int p;
    int t[20];
    if(m==n)
        s[m]=r[m];
    else
    {
        p=(m+n)/2;
        merge_sort(r,t,m,p);    //递归调用merge_soit()函数将r[m]〜r[p]归并成有序的t[m]〜t[p]
        merge_sort(r,t,p+1,n);    //递归一调用merge_sort()函数将r[p+l]〜r[n]归并成有序的t[p+l]〜t[n]
        merge(t,s,m,p,n);    //调用函数将前两部分归并到s[m]〜s[n】*/
    }
    return 0;
}
 
int main()
{
    int a[11];
    int i;
    printf("请输入10个数:\n");
    for(i=1;i<=10;i++)
        scanf("%d",&a[i]);    //从键盘中输入10个数
    merge_sort(a,a,1,10);    //调用merge_sort()函数进行归并排序
    printf("排序后的顺序是:\n");
    for(i=1;i<=10;i++)
        printf("%5d",a[i]);    //输出排序后的数据
    printf("\n");
    return 0;
}
运行结果:
请输入10个数:
695 458 362 789 12 15 163 23 2 986
排序后的顺序是:
2 12 15 23 163 362 458 695 789 986

技术要点:
归并是将两个或多个存序记录序列合并成一个有序序列。归并方法有多种,一次对两个有序记录序列进行归并,称为路归并排序,也有三路归并排序及多路归并排序。本实例是二路归并排序,基本方法如下:

(1) 将 n 个记录看成是 n 个长度为 1 的有序子表。

(2) 将两两相邻时有序无表进行归并。

(3) 重复执行步骤 (2) 直到归并成一个长度为 n 的有序表。
    作者:大学生新闻网    来源:大学生新闻网
    发布时间:2025-03-05    阅读:
    扫一扫 分享悦读
  • C语言二分查找算法,折半查找算法
  • 本实例采用二分查找法查找特定关键字的元素。要求用户输入数组长度,也就是有序表的数据长度,并输入数组元素和査找的关键字。
  • 03-05 关注:0
  • C语言归并排序算法
  • 用归并排序法对一组数据由小到大进行排序,数据分别为 695、458、362、789、12、 15、163、23、2、986。
  • 03-05 关注:0
  • C语言选择排序算法
  • 用选择排序法对一组数据由小到大进行排序,数据分别为 526、36、2、369、56、45、78、92、125、52。
  • 03-05 关注:0
  • C语言快速排序算法
  • 用快速排序法对一组数据由小到大进行排序,数据分别为 99、45、12、36、69、22、62、 796、4、696。
  • 03-05 关注:0
  • C语言直接插入排序算法
  • 插入排序是把一个记录插入到已排序的有序序列中,使整个序列在插入该记录后仍然有序。插入排序中较简单的种方法是直接插入排序
  • 03-03 关注:3
  • C语言冒泡排序算法
  • 用冒泡排序法对任意输入的 10 个数按照从小到大的顺序进行排序。
  • 03-03 关注:5
  • C语言希尔排序算法
  • 用希尔排序法对一组数据由小到大进行排序,数据分别为 69、56、12、136、3、55、46、 99、88、25。
  • 03-03 关注:3
主站蜘蛛池模板: 久久97精品久久久久久久看片 | 亚洲国产成人超福利久久精品 | 久久精品国产亚洲av久 | 久久久久久夜精品精品免费啦 | 欧美日韩在线精品成人综合网 | 对白脏话肉麻粗话av | 日本三级和搜子同屋的日子2电影 | 色欲欲www成人网站 色欲综合久久中文字幕网 色欲综合一区二区三区 | 精品国产乱码久久久久久口爆网站 | 两人免费视频 | 免费观看全黄做爰大片国产 | 亚洲日韩aⅴ在线视频 | 欧美成人禁片在线观看网址 | 成人欧美一区二区三区视频 | 国产目拍亚洲精品一区二区三区 | 我想看一级毛片免费的 | 国产三级成人 | 亚洲图色视频 | 中文字幕一区二区三区久久网站 | 视频在线亚洲 | 黄a无码片内射无码视频 | 男女做爽爽爽视频免费软件 | 美女扒开腿让男生捅 | 久久视频精品 | 免费二级毛片免费完整视频 | 亚洲激情综合在线 | 欧美日a| 亚洲精品无码av人在线观看国产 | selao久久国产精品 | 激情九月婷婷 | 粉嫩少妇内射浓精videos | 四虎国内精品一区二区 | 国产精品国内免费一区二区三区 | 国模大胆一区二区三区 | 一区二区三区四区在线观看视频 | 久久久久久久综合综合狠狠 | 亚洲国产成人久久综合野外 | 99久久婷婷国产综合亚洲 | 久久人妻内射无码一区三区 | 一级做a爱过程免费视频时看 | 97伦伦午夜电影理伦片 |