1.Java数组排序几种排序方法详细一点
2.java中的排序排序SORT怎么用
Java数组排序几种排序方法详细一点
在Java中,数组排序是源码原理常见的编程任务,可以通过多种算法实现,排序排序包括快速排序、源码原理physx 源码分析冒泡排序、排序排序选择排序和插入排序。源码原理下面详细介绍这几种排序方法:
1. 快速排序法:
快速排序是排序排序利用分治策略的一种排序算法。它通过选取基准元素,源码原理将数组分为两部分,排序排序一部分小于基准元素,源码原理另一部分大于基准元素,排序排序抽象模型源码然后递归地对这两部分继续进行快速排序。源码原理Java中的排序排序`Arrays.sort()`方法内部实际上是使用了快速排序算法。
示例代码:
```java
import java.util.Arrays;
public class Test2 {
public static void main(String[] args) {
int[] a = { 5,源码原理 4, 2, 4, 9, 1};
Arrays.sort(a); // 进行排序
for (int i : a) {
System.out.print(i);
}
}
}
```
2. 冒泡排序法:
冒泡排序是一种简单的排序算法,它重复地遍历要排序的排序排序数列,一次比较两个元素,夺宝源码文件如果它们的顺序错误就把它们交换过来。遍历数列的工作是重复地进行,直到没有再需要交换的元素为止。
示例代码:
```java
public static int[] bubbleSort(int[] args) {
for (int i = 0; i < args.length - 1; i++) {
for (int j = i + 1; j < args.length; j++) {
if (args[i] > args[j]) {
int temp = args[i];
args[i] = args[j];
args[j] = temp;
}
}
}
return args;
}
```
3. 选择排序法:
选择排序是另一种简单直观的排序算法。它的openkm文件源码工作原理是:首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。batis源码分析
示例代码:
```java
public static int[] selectSort(int[] args) {
for (int i = 0; i < args.length - 1; i++) {
int min = i;
for (int j = i + 1; j < args.length; j++) {
if (args[min] > args[j]) {
min = j;
}
}
if (min != i) {
int temp = args[i];
args[i] = args[min];
args[min] = temp;
}
}
return args;
}
```
4. 插入排序法:
插入排序是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常采用in-place排序(即只需用到O(1)的额外空间的排序)。
示例代码:
```java
public static int[] insertSort(int[] args) {
for (int i = 1; i < args.length; i++) {
for (int j = i; j > 0; j--) {
if (args[j] < args[j - 1]) {
int temp = args[j - 1];
args[j - 1] = args[j];
args[j] = temp;
} else {
break;
}
}
}
return args;
}
```
以上就是Java中常用的几种数组排序方法,每种方法都有其适用场景和优缺点。在实际应用中,可以根据具体需求选择合适的排序算法。
java中的SORT怎么用
Java中的Sort(排序)通常指的是Collections.sort() 对 List 的排序,该排序方式有两种不同改的使用方法:
第一种是list中的对象实现Comparable接口,如下
public class User implements Comparable<User>{
private String name;
private Integer order;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer getOrder() {
return order;
}
public void setOrder(Integer order) {
this.order = order;
}
public int compareTo(User arg0) {
return this.getOrder().compareTo(arg0.getOrder());
}
}
此时可以直接排序
public static void main(String[] args) {
User user1 = new User();
user1.setName("a");
user1.setOrder(1);
User user2 = new User();
user2.setName("b");
user2.setOrder(2);
List<User> list = new ArrayList<User>();
//此处add user2再add user1
list.add(user2);
list.add(user1);
Collections.sort(list);
for(User u : list){
System.out.println(u.getName());
}
}
第二种方法是根据Collections.sort重载方法来实现,例如:
public static void main(String[] args) {
User user1 = new User();
user1.setName("a");
user1.setOrder(1);
User user2 = new User();
user2.setName("b");
user2.setOrder(2);
List<User> list = new ArrayList<User>();
list.add(user2);
list.add(user1);
Collections.sort(list,new Comparator<User>(){
public int compare(User arg0, User arg1) {
return arg0.getOrder().compareTo(arg1.getOrder());
}
});
for(User u : list){
System.out.println(u.getName());
}
}