排序算法_
创始人
2024-05-13 06:30:19
0

一、选择排序

题目

arr[0~N-1]范围上,找到最小值所在的位置,然后把最小值交换到0位置。
arr[1~N-1]范围上,找到最小值所在的位置,然后把最小值交换到1位置。
arr[2~N-1]范围上,找到最小值所在的位置,然后把最小值交换到2位置。

arr[N-1~N-1]范围上,找到最小值位置,然后把最小值交换到N-1位置。

代码

package sort;public class SelectionSort {public int[] selectionSort(int[] arr) {if (arr == null) {return null;}for (int i = 0; i < arr.length - 1; i++) {int index = i;for (int j = i + 1; j < arr.length; j++) {if (arr[index] > arr[j]) {index = j;}}swap(arr, i, index);}return arr;}public void swap(int[] arr, int a, int b) {int num = arr[a];arr[a] = arr[b];arr[b] = num;}
}

二、冒泡排序

题目

在arr[0~N-1]范围上:
arr[0]和arr[1],谁大谁来到1位置;arr[1]和arr[2],谁大谁来到2位置…arr[N-2]和arr[N-1],谁大谁来到N-1位置
在arr[0~N-2]范围上,重复上面的过程,但最后一步是arr[N-3]和arr[N-2],谁大谁来到N-2位置
在arr[0~N-3]范围上,重复上面的过程,但最后一步是arr[N-4]和arr[N-3],谁大谁来到N-3位置

最后在arr[0~1]范围上,重复上面的过程,但最后一步是arr[0]和arr[1],谁大谁来到1位置

代码

package sort;public class BubbleSort {public int[] bubbleSort(int[] arr) {if (arr == null) {return null;}for (int i = 0; i < arr.length - 1; i++) {for (int j = 0; j < arr.length - i - 1; j++) {if (arr[j] > arr[j + 1]) {swap(arr, j, j + 1);}}}return arr;}public void swap(int[] arr, int a, int b) {int num = arr[a];arr[a] = arr[b];arr[b] = num;}
}

三、插入排序

题目

想让arr[0~0]上有序,这个范围只有一个数,当然是有序的。
想让arr[0~1]上有序,所以从arr[1]开始往前看,如果arr[1]
想让arr[0~i]上有序,所以从arr[i]开始往前看,arr[i]这个数不停向左移动,一直移动到左边的数字不再比自己大,停止移动。
最后一步,想让arr[0~N-1]上有序,arr[N-1]这个数不停向左移动,一直移动到左边的数字不再比自己大,停止移动。

代码

package sort;public class InsertionSort {public int[] insertionSort(int[] arr) {if (arr == null) {return null;}for (int i = 1; i < arr.length; i++) {for (int j = i; j > 0 && arr[j] < arr[j - 1]; j--) {swap(arr, j, j - 1);}}return arr;}public void swap(int[] arr, int a, int b) {int num = arr[a];arr[a] = arr[b];arr[b] = num;}
}

相关内容

热门资讯

建邺区双闸街道: 公众委员进区... 转自:南京晨报 晨报讯(通讯员 赵琦微 南京晨报/爱南京记者 孔芳芳)日前,第51期“公众委...
南京嘉信拍卖有限公司拍卖公告 转自:南京晨报 受有关单位委托,本公司将在中拍平台(https://paimai.caa12...
本周南京有两次降水过程 转自:南京晨报 晨报讯(南京晨报/爱南京记者 刘畅)气温又要重回“2”字头啦!3月10日起,...
高质量发展的中国充满合作机遇 来源:人民日报海外版图①图②图③图④图⑤图⑥图⑦图⑧一年一度的中国两会是世界了解中国的重要窗口。多国...
破解中小微企业融资难 中小微企业在推动就业和经济增长中发挥着重要作用,而融资难、融资贵的问题长期制约其发展。今年政府工作报...
北京成为全国领先的机器人技术创... 转自:千龙网能爬楼、能奔跑的人形机器人,成为医生助手的手术机器人,帮残障人士站起来的外骨骼机器人……...
对在华发展有信心 中国两会是跨国公司了解中国经济社会发展和政策走向的重要窗口。众多跨国公司负责人表示,中国两会释放的一...
全国医院薪酬改革引导专业发展与... 转自:南京晨报 ◎推动公立医院薪酬制度改革,补足医院儿科、精神科、急诊急救、中医、感染、病理...
今年就业目标如何实现?AI会导... 转自:上观新闻作为最基本的民生,就业不仅事关人民群众切身利益,更事关经济社会健康发展和国家长治久安,...
完善种业创新链条 抓产业创新,要守牢实体经济这个根基。种业是现代农业发展的基础,今年的政府工作报告提出,深入实施种业振...
物价温和回升态势没有改变 国家统计局数据显示,受春节错月等因素影响,2月份居民消费价格指数(CPI)环比下降0.2%,同比下降...
“雪王”IPO启示录:千亿港元...   炒股就看金麒麟分析师研报,权威,专业,及时,全面,助您挖掘潜力主题机会! 转自:白狐财经港交所...
建立健全基础制度规则 强化市场基础制度规则统一,是全国统一大市场建设的一项重要任务。全国政协委员、甘肃省工业和信息化厅副厅...
1.4万亿斤左右 粮食产量新目... 转自:工人日报  继我国粮食产量连续10年稳定在1.3万亿斤以上、2024年粮食产量迈上1.4万亿斤...
推动经营模式转型升级 今年的政府工作报告提出,发展新型农村集体经济。全国政协委员、民盟贵州省委副主委、贵州民族大学副校长崔...
中国“人造太阳”达到国际先进水...   新华社电 中国下一代“人造太阳”又建成一项关键系统!记者3月9日从中国科学院合肥物质科学研究院获...
文体旅融合打造文化高地新引擎 转自:内蒙古日报□蔡冬梅 李楷谨 苗雨蔚 崔妍  2023年11月22日,在包头市文联第七次代表大会...
川渝新能源汽车消费纠纷调处中心...   本报重庆讯(记者刘文新)近日,川渝新能源汽车消费纠纷 【下载黑猫投诉客户端】调处中心正式挂牌。该...
强农富农务必重视品牌 农业品牌建设是推动农业高质量发展的重要举措,是促进农民增收、增强农业竞争力的重要途径。要立足特色、提...
上海女子半马鸣金,但对齐名古屋... 转自:上观新闻3月9日,以“美耀她力量”为口号的2025上海女子半程马拉松成功举办,赵艳丽以1小时1...