Here you can find the source of quickSort2(int target[], int fromIndex, int length, int[] coSort)
private static void quickSort2(int target[], int fromIndex, int length, int[] coSort)
//package com.java2s; /*//from w w w . j a v a 2s . c o m * Redberry: symbolic tensor computations. * * Copyright (c) 2010-2013: * Stanislav Poslavsky <stvlpos@mail.ru> * Bolotin Dmitriy <bolotin.dmitriy@gmail.com> * * This file is part of Redberry. * * Redberry is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Redberry is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with Redberry. If not, see <http://www.gnu.org/licenses/>. */ public class Main { private static void quickSort2(int target[], int fromIndex, int length, int[] coSort) { // Insertion quickSort on smallest arrays if (length < 7) { for (int i = fromIndex; i < length + fromIndex; i++) for (int j = i; j > fromIndex && target[j - 1] > target[j]; j--) swap(target, j, j - 1, coSort); return; } // Choose a partition element, v int m = fromIndex + (length >> 1); // Small arrays, middle element if (length > 7) { int l = fromIndex; int n = fromIndex + length - 1; if (length > 40) { // Big arrays, pseudomedian of 9 int s = length / 8; l = med3(target, l, l + s, l + 2 * s); m = med3(target, m - s, m, m + s); n = med3(target, n - 2 * s, n - s, n); } m = med3(target, l, m, n); // Mid-size, med of 3 } int v = target[m]; // Establish Invariant: v* (<v)* (>v)* v* int a = fromIndex, b = a, c = fromIndex + length - 1, d = c; while (true) { while (b <= c && target[b] <= v) { if (target[b] == v) swap(target, a++, b, coSort); b++; } while (c >= b && target[c] >= v) { if (target[c] == v) swap(target, c, d--, coSort); c--; } if (b > c) break; swap(target, b++, c--, coSort); } // Swap partition elements back to middle int s, n = fromIndex + length; s = Math.min(a - fromIndex, b - a); vecswap(target, fromIndex, b - s, s, coSort); s = Math.min(d - c, n - d - 1); vecswap(target, b, n - s, s, coSort); // Recursively quickSort non-partition-elements if ((s = b - a) > 1) quickSort2(target, fromIndex, s, coSort); if ((s = d - c) > 1) quickSort2(target, n - s, s, coSort); } private static void quickSort2(short target[], int fromIndex, int length, int[] coSort) { // Insertion quickSort on smallest arrays if (length < 7) { for (int i = fromIndex; i < length + fromIndex; i++) for (int j = i; j > fromIndex && target[j - 1] > target[j]; j--) swap(target, j, j - 1, coSort); return; } // Choose a partition element, v int m = fromIndex + (length >> 1); // Small arrays, middle element if (length > 7) { int l = fromIndex; int n = fromIndex + length - 1; if (length > 40) { // Big arrays, pseudomedian of 9 int s = length / 8; l = med3(target, l, l + s, l + 2 * s); m = med3(target, m - s, m, m + s); n = med3(target, n - 2 * s, n - s, n); } m = med3(target, l, m, n); // Mid-size, med of 3 } int v = target[m]; // Establish Invariant: v* (<v)* (>v)* v* int a = fromIndex, b = a, c = fromIndex + length - 1, d = c; while (true) { while (b <= c && target[b] <= v) { if (target[b] == v) swap(target, a++, b, coSort); b++; } while (c >= b && target[c] >= v) { if (target[c] == v) swap(target, c, d--, coSort); c--; } if (b > c) break; swap(target, b++, c--, coSort); } // Swap partition elements back to middle int s, n = fromIndex + length; s = Math.min(a - fromIndex, b - a); vecswap(target, fromIndex, b - s, s, coSort); s = Math.min(d - c, n - d - 1); vecswap(target, b, n - s, s, coSort); // Recursively quickSort non-partition-elements if ((s = b - a) > 1) quickSort2(target, fromIndex, s, coSort); if ((s = d - c) > 1) quickSort2(target, n - s, s, coSort); } private static void swap(int x[], int a, int b, int[] coSort) { swap(x, a, b); swap(coSort, a, b); } /** * Swaps x[a] with x[b]. */ private static void swap(int x[], int a, int b) { int t = x[a]; x[a] = x[b]; x[b] = t; } private static void swap(int x[], int a, int b, long[] coSort) { swap(x, a, b); swap(coSort, a, b); } /** * Swaps x[a] with x[b]. */ private static void swap(long x[], int a, int b) { long t = x[a]; x[a] = x[b]; x[b] = t; } private static void swap(Object[] x, int a, int b, Object[] coSort) { swap(x, a, b); swap(coSort, a, b); } /** * Swaps x[a] with x[b]. */ private static void swap(Object[] x, int a, int b) { Object t = x[a]; x[a] = x[b]; x[b] = t; } private static void swap(int x[], int a, int b, Object[] coSort) { swap(x, a, b); swap(coSort, a, b); } private static void swap(short x[], int a, int b, int[] coSort) { swap(x, a, b); swap(coSort, a, b); } /** * Swaps x[a] with x[b]. */ private static void swap(short x[], int a, int b) { short t = x[a]; x[a] = x[b]; x[b] = t; } /** * Returns the index of the median of the three indexed integers. */ private static int med3(int x[], int a, int b, int c) { return (x[a] < x[b] ? (x[b] < x[c] ? b : x[a] < x[c] ? c : a) : (x[b] > x[c] ? b : x[a] > x[c] ? c : a)); } private static <T extends Comparable<T>> int med3(T[] x, int a, int b, int c) { return (x[a].compareTo(x[b]) < 0 ? (x[b].compareTo(x[c]) < 0 ? b : x[a].compareTo(x[c]) < 0 ? c : a) : (x[b].compareTo(x[c]) > 0 ? b : x[a].compareTo(x[c]) > 0 ? c : a)); } /** * Returns the index of the median of the three indexed integers. */ private static int med3(short x[], int a, int b, int c) { return (x[a] < x[b] ? (x[b] < x[c] ? b : x[a] < x[c] ? c : a) : (x[b] > x[c] ? b : x[a] > x[c] ? c : a)); } private static void vecswap(int x[], int a, int b, int n, int[] coSort) { for (int i = 0; i < n; i++, a++, b++) swap(x, a, b, coSort); } private static void vecswap(int x[], int a, int b, int n, long[] coSort) { for (int i = 0; i < n; i++, a++, b++) swap(x, a, b, coSort); } private static void vecswap(Object[] x, int a, int b, int n, Object[] coSort) { for (int i = 0; i < n; i++, a++, b++) swap(x, a, b, coSort); } private static void vecswap(int x[], int a, int b, int n, Object[] coSort) { for (int i = 0; i < n; i++, a++, b++) swap(x, a, b, coSort); } private static void vecswap(short x[], int a, int b, int n, int[] coSort) { for (int i = 0; i < n; i++, a++, b++) swap(x, a, b, coSort); } }