如何选择排序及其优化
发表于:2025-11-08 作者:千家信息网编辑
千家信息网最后更新 2025年11月08日,这篇文章主要讲解了"如何选择排序及其优化",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"如何选择排序及其优化"吧!我们先来看看最原始的版本for (in
千家信息网最后更新 2025年11月08日如何选择排序及其优化
这篇文章主要讲解了"如何选择排序及其优化",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"如何选择排序及其优化"吧!
我们先来看看最原始的版本
for (int i = 0; i < beg.length - 1; i++) {for (int j = i + 1; j < beg.length; j++) {if (beg[i] >= beg[j]) {int temp = beg[j];beg[j] = beg[i];beg[i] = temp; } }}for (int k = 0; k < beg.length; k++) { System.out.print(beg[k] + ",");}我们可以发现外面的循环每次都是第i个数和剩下的length-i-1个数做比较
如下图

优化:
每次遍历找出最大值和最小值,那么我们循环的次数就会少1/2
for (int i = 0; i < (beg.length - 1) / 2; i++) {int min = i;int max = i;for (int j = i + 1; j < beg.length - i; j++) { min = beg[i] >= beg[j] ? j : min; max = beg[i] >= beg[j] ? max : j; }if (min + max == beg.length - 1) {int temp3 = beg[beg.length - 1 - i];beg[beg.length - 1 - i] = beg[i];beg[i] = temp3; } else {int temp = beg[min];int temp2 = beg[max];beg[min] = beg[i];beg[max] = beg[beg.length - 1 - i];beg[i] = temp;beg[beg.length - 1 - i] = temp2; }}for (int k = 0; k < beg.length; k++) { System.out.print(beg[k] + ",");}最外层遍历少了1/2 而里层遍历又少随着最大值和最小值的缩小而缩小区间

这里需要考虑一下极值的情况即最大值和最小值刚好交换的情况,如图中1和9刚好是最大值与最小值
感谢各位的阅读,以上就是"如何选择排序及其优化"的内容了,经过本文的学习后,相信大家对如何选择排序及其优化这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!
排序
选择
最大
最小
最大值
情况
学习
个数
内容
循环
原始
区间
外层
就是
思路
文章
更多
极值
次数
版本
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
建立一个完整的网络安全体系
l服务器异常
永顺网络安全宣传
阀门选型软件开发商
一流网络安全示范学院
如何运行服务器安全
军工软件开发要求
计算机网络技术专业百度贴吧
群晖显示服务器已满
郑州众志软件开发有限公司
宽带连接服务器名称
江北区提供软件开发流程报价表
慈溪软件开发哪家好
千锋网络安全好吗
常见的蜂窝网络技术
政府行业网络安全痛点分析
建立数据库dbstu
打印机服务器需要什么配置
花雨庭服务器生存服怎么进
物联网无线网络技术在哪一次
网络安全对银行重要性
关于提升网络安全意识的演讲稿
如何梳理公司的软件开发流程
网络安全法中明确国家实行
邮箱服务器备份
甘孜州软件开发专业哪个好
小米路由软件开发
区块链、网络安全产品
长沙网络技术员招聘信息
百度网络安全大会