码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 算法--选择排序


    算法步骤

    1. /**
    2. * 选择排序
    3. *
    4. * @version 1.0
    5. * @date 2023/09/01 17:57:05
    6. */
    7. public class Select {
    8. /**
    9. * 升序选择排序
    10. *
    11. * @param a 待排序的数组
    12. * @date 2023/9/1 15:29:10
    13. */
    14. public static void sortAes(int[] a) {
    15. //数组长度
    16. int length = a.length;
    17. for (int i = 0; i <= length-2; i++) {
    18. //假设第一个元素为最小值
    19. int minIndex = i;
    20. for (int j = i+1; j <= length-1; j++) {
    21. //寻找最小值的下标
    22. if (a[minIndex] > a[j]) {
    23. minIndex = j;
    24. }
    25. }
    26. //将最小值下标对应的数据与第一个元素交换
    27. int minValue = a[minIndex];
    28. a[minIndex] = a[i];
    29. a[i] = minValue;
    30. }
    31. }
    32. /**
    33. * 降序选择排序
    34. *
    35. * @param a 待排序的数组
    36. * @date 2023/9/1 15:29:10
    37. */
    38. public static void sortDesc(int[] a) {
    39. int length = a.length;
    40. for (int i = 0; i <= length-2; i++) {
    41. //假设第一个元素是最大值
    42. int maxIndex = i;
    43. for (int j = i+1; j <= length-1; j++) {
    44. //寻找最大值元素的下标
    45. if (a[maxIndex] < a[j]) {
    46. maxIndex = j;
    47. }
    48. }
    49. //交换最大值
    50. int maxValue = a[maxIndex];
    51. a[maxIndex] = a[i];
    52. a[i] = maxValue;
    53. }
    54. }
    55. }
    56. public class SelectTest {
    57. public static void main(String[] args) {
    58. int[] array = {56, 88, 23, 99, 12, 34, -15, -45, 78, 67, 32};
    59. //升序排列
    60. //Select.sortAes(array);
    61. //降序排列
    62. Select.sortDesc(array);
    63. System.out.println(Arrays.toString(array));
    64. }
    65. }

  • 相关阅读:
    深信服云桌面用户忘记密码后的处理
    都闪开,这才是最牛x技术搜索引擎【云原生】
    ElasticSearch7.3学习(三十二)----logstash三大插件(input、filter、output)及其综合示例
    期货开户手续费是怎么查询?
    LeetCode刷题笔记【27】:贪心算法专题-5(无重叠区间、划分字母区间、合并区间)
    Java 集合面试题小结(1)
    MC-4/11/01/400 ELAU 软件允许用户完全访问相机设置
    【在Java中如何判断元素是否在集合中】
    基于R语言实现中介效应检验以及sobel检验代码
    C++ 变量的声明和初始化方式
  • 原文地址:https://blog.csdn.net/weixin_42614150/article/details/132867332
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号