写一段冒泡排序代码.
时间: 2024-04-25 09:19:27 浏览: 9
冒泡排序是一种简单的排序算法,它重复地遍历要排序列表,比较相邻的两个元素,并按照大小交换它们的位置,到整个列表排序完成。以下是一个示例的冒泡排序代码:
```python
def bubble_sort(arr):
n = len(arr)
for i in range(n-1):
for j in range(n-i-1):
if arr[j] > arr[j+1]:
arr[j], arr[j+1] = arr[j+1], arr[j]
return arr
```
相关问题
用JAVA写一段冒泡排序代码
### 回答1:
好的,我可以为您提供一段用Java语言实现的冒泡排序代码,如下:
```java
public static void bubbleSort(int[] arr) {
int n = arr.length;
for (int i = 0; i < n - 1; i++) {
for (int j = 0; j < n - i - 1; j++) {
if (arr[j] > arr[j + 1]) {
// 交换相邻两个数的位置
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
```
这段代码实现了对一个整型数组进行冒泡排序的功能。冒泡排序的思路是每次比较相邻的两个元素,如果它们的顺序不对就交换它们的位置,这样每一轮比较都可以使一个数归位。重复n-1轮即可完成排序,其中n是数组的长度。
### 回答2:
冒泡排序是一种比较简单的排序算法,其基本思想是通过相邻元素之间的比较和交换,依次将最大的元素冒泡到最后的位置。以下是用Java编写的冒泡排序代码:
```
public class BubbleSort {
public static void main(String[] args) {
int[] arr = {5, 2, 8, 9, 1, 3};
bubbleSort(arr);
System.out.println("排序后的数组:");
for (int i : arr) {
System.out.print(i + " ");
}
}
public static void bubbleSort(int[] arr) {
int length = arr.length;
for (int i = 0; i < length - 1; i++) {
for (int j = 0; j < length - 1 - i; j++) {
if (arr[j] > arr[j + 1]) {
// 交换位置
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
}
```
在上述代码中,我们创建了一个名为`BubbleSort`的类,并在`main`方法中定义了一个整型数组`arr`,其中包含待排序的元素。`bubbleSort`方法用于实现冒泡排序算法。
在冒泡排序中,我们使用两个嵌套的循环。外部循环用于控制比较轮数,内部循环用于比较相邻元素并进行交换操作。在每一轮比较中,如果相邻两个元素的顺序不正确,我们就交换它们的位置。重复这个过程,直到整个数组排序完成。
最后,我们在`main`方法中调用`bubbleSort`方法,并通过遍历数组的方式打印出排序后的数组元素。
运行以上代码,输出结果为:
```
排序后的数组:
1 2 3 5 8 9
```
以上就是用Java编写的冒泡排序代码。
### 回答3:
冒泡排序是一种基础的排序算法,在Java中可以这样实现:
```java
public class BubbleSort {
public static void main(String[] args) {
int[] arr = {5, 2, 8, 6, 1, 3, 7, 4}; // 待排序数组
bubbleSort(arr); // 调用冒泡排序方法
System.out.println("排序后的数组:");
for (int num : arr) {
System.out.print(num + " ");
}
}
public static void bubbleSort(int[] arr) {
int n = arr.length;
for (int i = 0; i < n - 1; i++) {
for (int j = 0; j < n - i - 1; j++) {
if (arr[j] > arr[j + 1]) {
// 交换相邻元素
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
}
```
以上代码演示了如何使用Java编写冒泡排序算法。首先定义一个`bubbleSort`方法用于实现冒泡排序,该方法接收一个整型数组作为参数。在冒泡排序方法中,使用两个嵌套的`for`循环来比较并交换相邻元素,将较大的元素逐渐“冒泡”到数组的末尾。在`main`方法中,我们创建一个待排序的整型数组,并调用`bubbleSort`方法对数组进行排序。最后,我们使用`for`循环遍历已排序的数组并将其打印输出。
LM写一段冒泡排序代码
以下是冒泡排序的Python代码:
```
def bubble_sort(arr):
n = len(arr)
for i in range(n):
# 每经过一轮i,都会将最大的数“冒泡”到数组末尾,因此只需要比较前n-i-1个数
for j in range(n-i-1):
if arr[j] > arr[j+1]:
# 如果前一个数大于后一个数,则交换位置
arr[j], arr[j+1] = arr[j+1], arr[j]
return arr
```
在这个代码中,我们首先定义了一个函数`bubble_sort`,它接受一个数组作为参数。我们使用`len`函数获取数组的长度,然后使用双重循环来遍历数组。在内部循环中,我们比较相邻的两个数,如果前一个数大于后一个数,则交换它们的位置。这样,每经过一轮外部循环,最大的数就会“冒泡”到数组的末尾。最后,我们返回排序后的数组。