6种字符串数组的java排序(Stringarraysort)注意,本⽂不是字符串排序,是字符串数组的排序。
⽅法分别是:
1、低位优先键索引排序
2、⾼位优先建索引排序
3、Java⾃带排序(经过调优的归并排序)
4、冒泡排序
5、快速排序
6、三向快速排序
时间复杂度:
最慢的肯定是冒泡,O(n的平⽅)
最快的是快速排序,平均 O(nlogn)
低位优先,O(nW),W是字符串长度,在字符串长度较短情况下和快速排序时间应该很接近
⾼位优先,O(n) - O(nW)
三向快速排序,O(n) - O(nW)
本⽂中使⽤的例⼦是⼀个5757⾏的随机字符串数组⽂本TXT,实际测试结果:
低位优先键索引排序:5 ms
⾼位优先键索引排序:8 ms
JAVA⾃带排序:9 ms
冒泡排序:284 ms
快速排序:8 ms
三向快速排序:12 ms
稳定的排序是:
低位优先键索引排序
⾼位优先建索引排序
归并排序(Java⾃带的排序算法),速度还⾏,关键是保持循环情况下的顺序稳定
低位优先:
public static void sort(String[] a, int w) {
int n = a.length;
int R = 256; // extend ASCII alphabet size
String[] aux = new String[n];
for (int d = w-1; d >= 0; d--) {
int[] count = new int[R+1];
for (int i = 0; i < n; i++)
count[a[i].charAt(d) + 1]++;
for (int r = 0; r < R; r++)
count[r+1] += count[r];
for (int i = 0; i < n; i++)
aux[count[a[i].charAt(d)]++] = a[i];
for (int i = 0; i < n; i++)
a[i] = aux[i];
}
}
⾼位优先:
JAVA⾃带排序:
Arrays.sort(arr);
冒泡:
public static void bubblingSort(String[] arr) {
int size = arr.length;
for(int i = 0; i<size-1; i++) {
for (int j = i+1; j<arr.length; j++) {
if(arr[i]pareTo(arr[j])>0) {
String temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
}
}
}
快速:
static void quickSort(String[] arr,int left,int right) //快速排序算法
{
String f,t;
int rtemp,ltemp;
ltemp=left;
rtemp=right;
f=arr[(left+right)/2]; //分界值
while(ltemp<rtemp)
{
while(arr[ltemp]pareTo(f)<0)
{
++ltemp;
}
while(arr[rtemp]pareTo(f)>0)
{
--rtemp;
}
if(ltemp<=rtemp)
{
t=arr[ltemp];
arr[ltemp]=arr[rtemp];
arr[rtemp]=t;
--rtemp;
++ltemp;
}
}
if(ltemp==rtemp)
{
ltemp++;
}
if(left<rtemp)
{
quickSort(arr,left,ltemp-1); //递归调⽤
}
if(ltemp<right)
{
quickSort(arr,rtemp+1,right); //递归调⽤
}
}
三向快速:
验证代码:
public static void main(String[] args) {
URL path = Resource("");
//不定长随机单词1000个
//File file = new Path()+"/");
//长度为5的单词,5757个
File file = new Path()+"/");
File file1 = new Path()+"/");
File file2 = new Path()+"/");
冒泡排序java代码详解File file3 = new Path()+"/");
File file4 = new Path()+"/");
File file5 = new Path()+"/");
String[] arr = (String[])2List(file).toArray(new String[0]);
//排序前
for(String s : arr) {
//System.out.String());
}
//>>####低位优先
TimeMillis.setStart();
LSD.sort(arr,5);
TimeMillis.setEnd("低位优先键索引排序:");
//排序后
for(String s : arr) {
//System.out.String());
}
//>>####⾼位优先
String[] arr1 = (String[])2List(file1).toArray(new String[0]); TimeMillis.setStart();
MSD.sort(arr1);
TimeMillis.setEnd("⾼位优先键索引排序:");
//排序后
for(String s : arr1) {
//System.out.String());
}
/
/>>####JAVA⾃带排序
String[] arr2 = (String[])2List(file2).toArray(new String[0]); TimeMillis.setStart();
Arrays.sort(arr2);
TimeMillis.setEnd("JAVA⾃带排序:");
//排序后
for(Object s : arr2) {
//System.out.String());
}
//>>####冒泡排序
String[] arr3 = (String[])2List(file3).toArray(new String[0]); TimeMillis.setStart();
bubblingSort(arr3);
TimeMillis.setEnd("冒泡排序:");
//排序后
for(String s : arr3) {
//System.out.String());
}
//>>####快速排序
String[] arr4 = (String[])2List(file4).toArray(new String[0]); TimeMillis.setStart();
quickSort(arr4,0,5756);
TimeMillis.setEnd("快速排序:");
//排序后
for(String s : arr4) {
/
/System.out.String());
}
//>>####三向快速排序
String[] arr5 = (String[])2List(file5).toArray(new String[0]); TimeMillis.setStart();
Quick3string.sort(arr5);
TimeMillis.setEnd("三向快速排序:");
//排序后
for(String s : arr5) {
//System.out.String());
}
}
运⾏多次结果相近:
低位优先键索引排序:8 ms
⾼位优先键索引排序:10 ms
JAVA⾃带排序:15 ms
冒泡排序:315 ms
快速排序:9 ms
三向快速排序:13 ms
⽤到的数据txt⽂件下载:
ReadFiledata帮助类:
import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.util.ArrayList;
import java.util.List;
public class ReadFiledata {
public static String txt2String(File file){
StringBuilder result = new StringBuilder();
try{
BufferedReader br = new BufferedReader(new FileReader(file));
String s = null;
while((s = br.readLine())!=null){
result.append(System.lineSeparator()+s);
}
br.close();
}catch(Exception e){
e.printStackTrace();
}
String();
}
public static List<String> txt2List(File file){
try{
BufferedReader br = new BufferedReader(new FileReader(file)); List<String> list = new ArrayList<String>();
String s;
while((s = br.readLine())!=null){
list.add(s);
}
br.close();
return list;
}catch(Exception e){
e.printStackTrace();
}
return null;
}
public static Object[] txt2Array(File file){
return txt2List(file).toArray();
}
}
View Code
参考书⽬:《算法 4th》
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
java冒泡排序原理
« 上一篇
Java实验四(题目、解析及实例代码)
下一篇 »
热门文章
-
wps表格正则表达式
2024-12-28 -
6到8位数字或英文的正则
2024-12-28 -
整数最多12位,小数6位的正则表达式
2024-12-28 -
JS正则验证6位数字组成,验证纯中文组成
2024-12-28 -
java 6位数字正则表达式
2024-12-28 -
7位整数两位小数的正则
2024-12-27 -
flutter 11位数字正则
2024-12-27 -
validators.pattern8位数字正则表达式
2024-12-27 -
14位固定后4位数字的正则表达式
2024-12-27 -
grep 正则 7位数字
2024-12-27 -
11位数字正则表达式
2024-12-27 -
10个(含10)以内字母或字母数字的正则表达式
2024-12-27 -
验证 正则
2024-12-27 -
Oracle正则表达式汇总
2024-12-27 -
jmeter正则
2024-12-27 -
element rules 正则
2024-12-27 -
详解Sed命令的用法与正则表达式元字符
2024-12-27 -
flutter 负数正则表达式
2024-12-27 -
验证账号是否合法的正则表达式
2024-12-27 -
ignore files and folders正则 -回复
2024-12-27
最新文章
-
excel列数转字母算法
2024-12-28 -
以0开头以1结尾的二进制数字串的正则表达式
2024-12-28 -
文本格式提取数值 -回复
2024-12-28 -
为整数添加千分符的正则表达式
2024-12-28 -
正则限制数字
2024-12-28 -
element 表单校验位数
2024-12-28
发表评论