java链表实现快排
链表文件
package sort;
public class SqList {
public int LIST_INIT_SIZE = 8;//链表的原始大小
private int INCREMENT = 1;//链表的增量大小
private Object[] SqList = null;//链表
private int curIndex = 0;//当前位置
/**
* 初始化链表
* */
public void initList(){
SqList = new Object[LIST_INIT_SIZE];
}
/**
* 向链表中插入元素
* */
public void insertList(Object o){
if(curIndex > LIST_INIT_SIZE-1){//判断当前链表是否已经满
System.out.println("从新分配空间");
LIST_INIT_SIZE += INCREMENT;
Object []temp = new Object[LIST_INIT_SIZE];
for(int i=0; i<curIndex; i++)
{
temp[i]=SqList[i];
}
SqList = null;
SqList = temp;
}
//链表中如果不让其包含重复元素,则加入这段代码
/*
if(isContain(o))
{
System.out.println("链表中已包含此元素"+o);
}else
{
}
*/
SqList[curIndex++] = o;
}
/**
* 判断链表中是否包含某元素
* */
private Boolean isContain(Object o){
for(int i = 0; i<curIndex; i++){
if(SqList[i].equals(o))
return true;
}
return false;
}
/**
* 删除链表中的某元素
*
* 如果包含重复元素都删除
* */
public void delete(Object o){
for(int i = 0; i<curIndex; i++){
if(SqList[i].equals(o))
{
for(int j=i;j<curIndex-1;j++)
{
SqList[j]=SqList[j+1];
}
curIndex--;
continue;
}
if(i==curIndex-1)
{
System.out.println("不存在此元素"+o);
}
}
}
/**
* 获取链表中的某个元素
* */
public Object getElement(int i)
{
if (i < 0 || i > curIndex)
{
System.out.println("获取位置超出了链表中元素个数"+curIndex);
}
return SqList[i];
}
/**
* 打印链表
* */
public void print()
{
for(int i=0;i<curIndex;i++)
{
System.out.print(SqList[i]+"\t");
}
System.out.println();
}
/**
* 交换链表中的两个元素
* */
public void swap(SqList L,int low,int high){
System.out.println("before swap:low-"+SqList[low]+" high-"+SqList[high]);
Object temp = null;
temp = SqList[low];
SqList[low] = SqList[high];
SqList[high] = temp;
System.out.println("after swap:low-"+SqList[low]+" high-"+SqList[high]);
}
}
快排
package sort;
/*快排:两个指针low和high,枢轴记录的关键字为pivotkey,
* 首先从high所指位置起向前搜索,找到第一个关键字小于pivotkey的记录和枢轴记录交换,
* 然后从low所指位置向后搜索,找到第一个关键字大于pivotkey的记录和枢轴记录交换,
* 重复这两步直到low=high为止*/
public class quickSort {
public void QuickSort(SqList L){
QSort(L,0,L.LIST_INIT_SIZE-1);
}
public void QSort(SqList L,int low,int high){
int pivot;
if(low<high){
pivot = Partition(L,low,high);
QSort(L,low,pivot-1);
QSort(L,pivot+1,high);
}
}
public int Partition(SqList L,int low,int high){
System.out.println("start low:"+low+",high:"+high);
int pivotkey;
pivotkey = (Integer) L.getElement(low);//用子表的第一个记录作枢纽记录
System.out.println("pivotkey:"+pivotkey);
while(low<high){//从表的两端交替向中间扫描
while(low<high && (Integer)L.getElement(high)>=pivotkey)
high--;
System.out.println("1-low:"+low+",high:"+high);
L.swap(L,low,high);//将比枢轴记录小的记录交换到低端
while(low<high && (Integer)L.getElement(low)<=pivotkey )
low++;
System.out.println("2-low:"+low+",high:"+high);
L.swap(L,low,high);//将比枢轴记录大的记录交换到高端
}
System.out.println("low:"+low+",high:"+high);
return low;//返回枢轴所在位置
}
public static void main(String[] args) {
SqList sqList = new SqList();
sqList.initList();
sqList.insertList(49);
sqList.insertList(38);
sqList.insertList(65);
sqList.insertList(97);
sqList.insertList(76);
sqList.insertList(13);
sqList.insertList(27);
sqList.insertList(49);
sqList.print();
quickSort quickSort = new quickSort();
quickSort.QuickSort(sqList);
sqList.print();
System.out.println("第2个元素是:"+sqList.getElement(1));
System.out.println("第4个元素是:"+sqList.getElement(3));
}
}
java链表实现快排的更多相关文章
- 63.如何对单链表进行快排?和数组快排的分析与对比[quicksort of array and linked list]
[本文链接] http://www.cnblogs.com/hellogiser/p/quick-sort-of-array-and-linked-list.html [题目] 单链表的特点是:单向. ...
- Java 排序(快排,归并)
Java 排序有Java.util.Arrays的sort方法,具体查看JDK API(一般都是用快排实现的,有的是用归并) package yxy; import java.util.Arrays; ...
- 记录一个基于Java的利用快排切分来实现快排TopK问题的代码模板
使用快排切分实现快排和TopK问题的解题模板 import java.util.Arrays; public class TestDemo { public static void main(Stri ...
- UVA 1152 4 Values whose Sum is 0 (枚举+中途相遇法)(+Java版)(Java手撕快排+二分)
4 Values whose Sum is 0 题目链接:https://cn.vjudge.net/problem/UVA-1152 ——每天在线,欢迎留言谈论. 题目大意: 给定4个n(1< ...
- Java常见的几种排序算法-插入、选择、冒泡、快排、堆排等
本文就是介绍一些常见的排序算法.排序是一个非常常见的应用场景,很多时候,我们需要根据自己需要排序的数据类型,来自定义排序算法,但是,在这里,我们只介绍这些基础排序算法,包括:插入排序.选择排序.冒泡排 ...
- C语言实现单向链表及其各种排序(含快排,选择,插入,冒泡)
#include<stdio.h> #include<malloc.h> #define LEN sizeof(struct Student) struct Student / ...
- 折半、快排、插入排序的Java实现
插入排序 import java.util.Arrays; public class InsertionSort { /** * 对数组里面进行插入排序 * 参数1 数组 * 参数2 数组大小 */ ...
- 快排+java实现
import java.util.Arrays; public class QuickSort { //三数取中法.取出不大不小的那个位置 public static int getPivotPos( ...
- 待字闺中之快排单向链表;leetcode之Sort List
题目来源.待字闺中.原创@陈利人 .欢迎大家继续关注微信公众账号"待字闺中" 分析:思路和数据的高速排序一样,都须要找到一个pivot元素.或者节点. 然后将数组或者单向链表划分为 ...
随机推荐
- NYOJ-102 次方求模
次方求模 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 求a的b次方对c取余的值 输入 第一行输入一个整数n表示测试数据的组数(n<100)每组测试只有一 ...
- Q & A
1 使用linux命令或者shell实现:文件words存放英文单词,格式为每行一个英文单词(单词可以重复),统计这个文件中出现次数最多的前10个单词. cat words.txt | sort | ...
- EditText文本中用正则匹配是否包含数字,及判断文本只能是纯汉字或纯字母
遇到判断EditText中文本,是否为制定格式 EditText et; Button btn; @Override protected void onCreate(Bundle savedInsta ...
- log4j.properties全配置 (转)
###############################log4j.properties############################### ##### Global Log Leve ...
- 自动安装memcached服务端与PHP扩展Memcached
该脚本基于阿里云服务器安装脚本,并只能运用于centos / aliyun os,该脚本使用时,需要与阿里云安装脚本的install.sh放在同一目录下.有缘人切忌乱用: #! /bin/bash # ...
- JavaScript 属性操作
<!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...
- js--数组去重3种方法
js数组去重的三种常用方法总结 第一种是比较常规的方法 思路: 1.构建一个新的数组存放结果 2.for循环中每次从原数组中取出一个元素,用这个元素循环与结果数组对比 3.若结果数组中没有该元素,则存 ...
- 《JS正则表达式》
1.精通 JS正则表达式: http://www.cnblogs.com/aaronjs/archive/2012/06/30/2570970.html 2.js常用正则表达式: http://www ...
- Java实现二分查找算法
Java程序员总该玩点基本的算法. 1.前提:二分查找的前提是需要查找的数组必须是已排序的,我们这里的实现默认为升序 2.原理:将数组分为三部分,依次是中值(所谓的中值就是数组中间位置的那个值)前,中 ...
- 用Bash脚本将Linux普通用户添加为系统管理员
将Linux普通用户添加为系统管理员在Gnome或KDE这样强大与完善的桌面环境下是非常简单的事情,一般来说在用户设置的对话框里就直接有相应选项.不过,出于简洁与高效的风格,自己目前并未使用这些高端但 ...