《数据结构》之内部排序算法比较

本文介绍了直接插入排序、折半插入排序、希尔排序、冒泡排序和快速排序的实现,并通过示例展示了每种算法的比较次数和移动次数。此外,还提到了前端开发的学习资源,包括零基础到进阶的体系化学习资料。
摘要由CSDN通过智能技术生成

{

int i, j;

int tmp;

for (i = 1; i < n; i++) //for循环内一定比较了n-1次,if判断语句

{

if (a[i] < a[i - 1]) //一旦出现了逆序的关键字,就进行插入

{

tmp = a[i];

j = i - 1;

num_compare++;

do //往后移动一个位置,腾空间给tmp;

{

a[j + 1] = a[j];

num_move++; //移动加一

j–;

num_compare++; //比较次数加一

}

while (j >= 0 && a[j] > tmp);

a[j + 1] = tmp; //最后把tmp放在对应的位置

num_move += 2; //移动的temp

}

}

}

//折半插入排序法

//把无序区插入到有序区里,由于前面的插入排序法实现了有序,所以直接在

//有序区利用折半查找来寻找的改进算法

void BinInsertSort(int a[], int n)

{

int i, j, low, high, mid;

int tmp;

for (i = 1; i < n; i++) //已经比较了n-1次

{

if (a[i] < a[i - 1])

{

tmp = a[i];

low = 0;

high = i - 1;

num_compare++;

while (low <= high)

{

num_compare++; //while进入比较

mid = (low + high) / 2;

if (tmp < a[mid])

high = mid - 1;

else

low = mid + 1;

}

for (j = i - 1; j >= high + 1; j–)

{

a[j + 1] = a[j];

num_move++; //移动次数加一

}

a[high + 1] = tmp;

num_move += 2; //tmp交换

}

}

}

///

//希尔排序算法

void ShellSort(int a[], int n)

{

int i, j, d;

int tmp;

d = n / 2;

while (d > 0)

{

for (i = d; i < n; i++)

{

tmp = a[i];

j = i - d;

while (j >= 0 && tmp < a[j])

{

num_compare++;

num_move++;

a[j + d] = a[j];

j = j - d;

}

a[j + d] = tmp;

num_move += 2; //tmp进行两次操作

}

d = d / 2;

}

}

///

//冒泡排序算法

void BubbleSort(int a[], int n)

{

int i, j;

int tmp;

for (i = 0; i < n - 1; i++)

{

for (j = n - 1; j > i; j–)

if (a[j] < a[j - 1])

{

num_compare++;

num_move += 3;

tmp = a[j - 1];

a[j - 1] = a[j];

a[j] = tmp;

}

}

}

/

/快速排序算法/

int partition(int a[], int s, int t) //一趟划分

{

int i = s, j = t;

int tmp = a[i]; //以a[i]为基准

while (i < j) //从两端交替向中间扫描,直至i=j为止

{

while (j > i && a[j] >= tmp)

{

j–; //从右向左扫描,找一个小于tmp的a[j]

num_compare++; //进行比较

}

a[i] = a[j]; //找到这样的a[j],放入a[i]处

num_move++; //移动+1

while (i < j && a[i] <= tmp)

{

i++; //从左向右扫描,找一个大于tmp的a[i]

num_compare++; //比较加一

}

a[j] = a[i]; //找到这样的a[i],放入a[j]处

num_move++; //移动加一

}

a[i] = tmp;

num_move += 2; //temp的交换

return i;

}

void QuickSort(int a[], int s, int t)

//对a[s…t]的元素进行快速排序

{

int i;

if (s < t) //区间内至少存在两个元素的情况

{

i = partition(a, s, t);

QuickSort(a, s, i - 1); //对左区间递归排序

QuickSort(a, i + 1, t); //对右区间递归排序

}

}

/

void menu()

{

printf(“***************************************************\n”);

printf(“\t\t1.直接插入排序法\n”);

printf(“\t\t2.折半插入排序法\n”);

printf(“\t\t3.希尔排序法\n”);

printf(“\t\t4.冒泡排序法\n”);

printf(“\t\t5.快速排序法\n”);

printf(“\t\t6.效率比较\n”);

printf(“\t\t7.退出\n”);

printf(“***************************************************\n”);

printf(“请选择操作:”);

}

void printArray(int a[]) //打印数组数据

{

int i;

for (i = 0; i < MAX; i++)

printf(“%2d%c”, a[i], (i+1)%40 ? ’ ’ : ‘\n’);

putchar(10);

}

//调用直接插入排序的实现函数,即菜单1

void op1(int a[])

{

GetaandArray(a);

printf(“伪随机数已经生成的20000个新的随机数\n”);

//打印排序前的数组

// printArray(a);

InsertSort(a, MAX);

// printf(“\n利用直接插入排序后的数列如下:\n”);

//打印排序后的数组

// printArray(a);

printf(“\n\n直接插入排序法:\n一共比较了%d次,移动了%d次\n”, num_compare, num_move);

st[0].num_compare = num_compare;

st[0].num_move = num_move;

strcpy(st[0].name, “直接插入排序”);

}

void op2(int a[])

{

GetaandArray(a);

printf(“已经生成20000个新的随机数\n”);

//打印排序前的数组

// printArray(a);

num_compare = 0;

num_move = 0;

BinInsertSort(a, MAX);

// printf(“\n利用折半插入排序后的数列如下:\n”);

//打印排序后的数组

// printArray(a);

printf(“\n\n折半插入排序:\n一共比较了%d次,移动了%d次\n”, num_compare, num_move);

st[1].num_compare = num_compare;

st[1].num_move = num_move;

strcpy(st[1].name, “折半插入排序”);

}

void GetaandArray(int a[]) //为数组获得随机数

{

int i;

for (i = 0; i < MAX; i++)

a[i] = rand() % 100;

}

void op3(int a[])

{

GetaandArray(a);

printf(“已经生成20000个新的随机数\n”);

//打印排序前的数组

//printArray(a);

num_compare = 0;

num_move = 0;

ShellSort(a, MAX);

//printf(“\n利用希尔排序算法后的数列如下:\n”);

//打印排序后的数组

//printArray(a);

printf(“\n\n希尔排序算法:\n一共比较了%d次,移动了%d次\n”, num_compare, num_move);

st[2].num_compare = num_compare;

st[2].num_move = num_move;

strcpy(st[2].name, “希尔排序算法”);

}

void op4(int a[])

{

GetaandArray(a);

printf(“已经生成20000个新的随机数\n”);

//打印排序前的数组

// printArray(a);

num_compare = 0;

num_move = 0;

BubbleSort(a, MAX);

// printf(“\n利用冒泡排序法后的数列如下:\n”);

//打印排序后的数组

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

前15.PNG

前16.PNG

由于文档内容过多,为了避免影响到大家的阅读体验,在此只以截图展示部分内容,详细完整版的JavaScript面试题文档,或更多前端资料可以点此处免费获取

1713610871144)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

[外链图片转存中…(img-bSoRnQs2-1713610871145)]

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

[外链图片转存中…(img-Z054zO8X-1713610871145)]

最后

[外链图片转存中…(img-ubNyrtW6-1713610871146)]

[外链图片转存中…(img-Pu1Ydd7f-1713610871146)]

由于文档内容过多,为了避免影响到大家的阅读体验,在此只以截图展示部分内容,详细完整版的JavaScript面试题文档,或更多前端资料可以点此处免费获取

  • 15
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值