冒泡排序Java

排序算法

冒泡排序是一种简单的排序算法,它重复地遍历待排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。遍历数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。下面是使用JavaScript实现冒泡排序的一个示例:

JavaScript示例:

java 复制代码
function bubbleSort(arr) { var len = arr.length; for (var i = 0; i < len - 1; i++) 
{ // 遍历所有数组元素
 for (var j = 0; j < len - 1 - i; j++) { 
 // 每轮遍历都比当前轮次少一个元素 
 if (arr[j] > arr[j + 1]) { 
 // 如果前一个元素大于后一个元素 // 交换它们的位置 
 var temp = arr[j]; arr[j] = arr[j + 1]; arr[j + 1] = temp; } } } 
 return arr; // 返回排序后的数组 
 } 
 // 示例 
 var unsortedArray = [64, 34, 25, 12, 22, 11, 90]; console.log("排序前:", unsortedArray); var sortedArray = bubbleSort(unsortedArray); console.log("排序后:", sortedArray);

冒泡排序的效率最低发生在输入数组已经是完全逆序的状态时。每一轮比较,冒泡排序都要将当前未排序部分的最大值移动到正确的位置,因此当数组逆序时,需要进行n-1轮比较(n为数组长度),且每轮内部的比较次数几乎达到最大,即n*(n-1)/2次。所以总的比较次数是(n-1) + (n-2) + ... + 1,这是一个等差数列求和,其结果为n*(n-1)/2。在这种情况下,冒泡排序的时间复杂度为O(n^2),效率极低。

相关推荐
安冬的码畜日常8 分钟前
【D3.js in Action 3 精译】1.2.2 可缩放矢量图形(三)
开发语言·前端·javascript·信息可视化·数据可视化
天荒地老笑话么19 分钟前
Spring MVC数据绑定和响应——数据回写(二)JSON数据的回写
java·spring·java-ee·json·mvc
天荒地老笑话么20 分钟前
Spring MVC的高级功能——异常处理(一)简单异常处理器
java·spring·java-ee·mvc
战神刘玉栋29 分钟前
《后端程序猿 · 基于 Lettuce 实现缓存容错策略》
java·spring·缓存
hycccccch34 分钟前
Java&MySQL 学习(基础)
java·开发语言·笔记·学习·mysql
芋芋qwq39 分钟前
Lua、AB包热更新总结
开发语言·lua
Filwaod1 小时前
八、【源码】Aware感知对象
java·spring·源码
LiZhen7981 小时前
list.toArray(new String[0])详解
java·list
Flying_Fish_roe1 小时前
spring-08
java·后端·spring
C or Cpp1 小时前
C++协程
java·数据结构·c++