当前位置: 首页 > news >正文

了解冒泡排序

1

package com.mypackage.array;import java.util.Arrays;public class Demo07 {public static void main(String[] args) {int[] a = {3,2,6,7,4,5,6,34,56,7};int[] sort1 = sort1(a);    //调用我们自己写的排序方法后,返回一个排序后的数组System.out.println(Arrays.toString(sort1));     //降序,会输出[56, 34, 7, 7, 6, 6, 5, 4, 3, 2]int[] sort2 = sort2(a);    //调用我们自己写的排序方法后,返回一个排序后的数组System.out.println(Arrays.toString(sort2));     //降序,会输出[2, 3, 4, 5, 6, 6, 7, 7, 34, 56]}//冒泡排序//1.比较数组中两个相邻的元素,如果第一个数比第二个数大,就交换两个数的位置//2.每一次比较,都会产生一个最大或者最小的数字//3.下轮就会少一次排序//4.一次循环,直到结束public static int[] sort1 (int[] array){int temp = 0;     //临时变量//外层循环,判断我们要走几次for (int i = 0; i < array.length-1; i++) {//内层循环,比较两个数,如果第一个数比第二个数大则交换位置for (int j = 0; j < array.length-1-i; j++) {if (array[j+1] > array[j]) {temp = array[j];array[j] = array[j+1];array[j+1] = temp;}}}return array;}public static int[] sort2 (int[] array){int temp = 0;     //临时变量//外层循环,判断我们要走几次for (int i = 0; i < array.length-1; i++) {//内层循环,比较两个数,如果第一个数比第二个数大则交换位置for (int j = 0; j < array.length-1-i; j++) {if (array[j+1] < array[j]) {temp = array[j];array[j] = array[j+1];array[j+1] = temp;}}}return array;}
}

优化程序,减少不必要的循环次数:

public static int[] sort3 (int[] array){int temp = 0;     //临时变量//外层循环,判断我们要走几次for (int i = 0; i < array.length-1; i++) {boolean flag = false;  //内层循环,比较两个数,如果第一个数比第二个数大则交换位置for (int j = 0; j < array.length-1-i; j++) {if (array[j+1] < array[j]) {temp = array[j];array[j] = array[j+1];array[j+1] = temp;flag = true;}}if (flag == false){break;}/*若flag没有变成true,说明没有经历if结构,即在一次循环中,各个数都是按顺序排列的,也就没有必要再进行下面的循环所以break跳出循环*/}return array;
}
http://www.lryc.cn/news/168967.html

相关文章:

  • 群辉 Synology NAS Docker 安装 RustDesk-server 自建服务器只要一个容器
  • 为什么要有override
  • Linux界的老古董
  • 安卓逆向 - Xposed入门教程
  • 【嵌入式】2024届校招岗位汇总
  • Docker搭建ELK日志采集服务及Kibana可视化图表展示
  • SpringBoot结合MyBatis实现多数据源配置
  • 单个vue echarts页面
  • 【web开发】6、Django(1)
  • 第29节-PhotoShop基础课程-滤镜库
  • 空间(蓝桥杯)
  • 蓝桥杯2023年第十四届省赛真题-更小的数--题解
  • SpringBoot详解
  • typescript 类型断言
  • 如何确定自己是否适合做程序员?
  • LabVIEW以编程方式查找系统中DAQ设备的设备名称
  • 23、mysql数据库的安装
  • 【实战详解】如何快速搭建接口自动化测试框架?Python + Requests
  • Linux安全加固:保护你的服务器
  • 【C++初阶】C++STL详解(四)—— vector的模拟实现
  • VS code 下 makefile 【缺少分隔符 停下来】 报错解决方法
  • 虹科案例 | Zuellig Pharma和ELPRO通过符合GDP标准的温度监测和高效的温度数据管理为未来发展奠定基础
  • 为啥我的第二个for循环不加框红的代码就运行失效呢?(文末赠书)
  • Java高级之注解
  • 【SpringMVC】JSON数据传输与异常处理的使用
  • LeNet-5
  • Anaconda bug
  • xen-trap
  • 微服务架构介绍
  • 235. 二叉搜索树的最近公共祖先