M313-Algorithmique-avancee/tests/TP2/TrisTestEtudiant.java

230 lines
5.6 KiB
Java
Raw Permalink Normal View History

2020-09-07 18:00:09 +02:00
package TP2;
import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail;
import java.util.Arrays;
import java.util.Random;
import org.junit.After;
import org.junit.AfterClass;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Test;
/** This class contains testing methods for sorting.<br>
*
* @author Dr. Denis Pallez<br>
* <a href="http://denispallez.i3s.unice.fr">http://denispallez.i3s.unice.fr</a>
*/
public class TrisTestEtudiant {
// array containing values to be sorted
protected static int[] nombres;
// size of the array to be sorted
protected static final int SIZE = 10;
// array will contain values in [1, MAX_VALUE]
protected static final int MAX_VALUE = 10;
// Random number generator
static Random generator ;
/** check whether array numbers is correctly sorted or not */
protected boolean arraySorted(int[] numbers) {
for (int i = 0; i < numbers.length - 1; i++) {
if (numbers[i] > numbers[i + 1]) {
return false;
}
}
return true;
}
/** initialize an array with random values*/
protected void initRandom() {
for (int i = 0; i < nombres.length; i++) {
nombres[i] = generator.nextInt(MAX_VALUE);
}
}
/** create an array sorted in the decreasing order*/
protected void initWorst() {
for (int i = 0; i < nombres.length; i++) {
nombres[i] = MAX_VALUE-i;
}
}
/** init an array with values already sorted*/
protected void initBest() {
for (int i = 0; i < nombres.length; i++) {
nombres[i] = i;
}
}
/** initialize an array with random values that could appear several times*/
protected void initSameValues() {
final int NBVAL_DIFF = nombres.length/2 ;
int[] values = new int[NBVAL_DIFF];
for (int i=0;i<NBVAL_DIFF;i++) {
values[i] = generator.nextInt(MAX_VALUE) ;
}
for (int i=0;i<nombres.length;i++) {
nombres[i] = values[generator.nextInt(NBVAL_DIFF)] ;
}
}
public static void triRapide(int[] numbers) {
2020-09-15 15:31:41 +02:00
//quickSort();
2020-09-07 18:00:09 +02:00
}
private static void exchange(int[] t, int i, int j) {
int temp = t[i];
t[i] = t[j];
t[j] = temp;
}
public static void triFusion(int[] numbers) {
mergeSort(numbers, 0, numbers.length);
}
private static void mergeSort(int[] tab, int min, int max) {
int mid = 0;
if(min != max) {
mid = (min+max)/2;
mergeSort(tab, min, mid);
mergeSort(tab, mid+1, max);
int[] tmpTab = new int[max-min+1];
int[] t1 = Arrays.copyOfRange(tab, min, mid+1);
int[] t2 = Arrays.copyOfRange(tab, mid+1, max);
Fusion(t1, t2, tmpTab);
for(int i=0; i < max-min; i++) {
tab[min+i] = tmpTab[i];
}
}
}
private static void Fusion(int[] tab1, int[] tab2, int[] tab) {
int i = 0; int i1 = 0; int i2 = 0;
while(i1 < tab1.length && i2 < tab2.length) {
if(tab1[i1] < tab2[i2]) {
tab[i] = tab1[i1];
i++;i1++;
} else {
tab[i] = tab2[i2];
i++;i2++;
}
}
while(i1<tab1.length) {
tab[i] = tab1[i1];
i++;i1++;
}
while(i1<tab2.length) {
tab[i] = tab2[i2];
i++;i2++;
}
}
private static void quickSort(int[] numbers, int min, int max) {
int i = min, j = max;
// Get the pivot element from the middle of the list
int pivot = numbers[min + (max - min) / 2];
int[] newij = partitionnerPivot(numbers, i,j, pivot) ;
i=newij[0] ; j=newij[1] ;
// Recursion
if (min < j)
quickSort(numbers, min, j);
if (i < max)
quickSort(numbers, i, max);
}
2020-09-15 15:31:41 +02:00
private static int[] partitionnerPivot(int[] numbers, int i, int j, int pivot) {
// TODO Auto-generated method stub
return null;
}
2020-09-07 18:00:09 +02:00
@Before
public void setUp() throws Exception {
}
@After
public void tearDown() throws Exception {
}
@BeforeClass
public static void setUpBeforeClass() throws Exception {
generator = new Random() ;
nombres = new int[SIZE];
System.out.println("******************") ;
System.out.println("Test de tris de tableaux à "+SIZE+" éléments:") ;
}
@AfterClass
public static void tearDownAfterClass() throws Exception {
generator=null ;
nombres=null ;
}
@Test
public void testRapideRandomCase() {
initRandom();
long startTime = System.nanoTime();
triRapide(nombres);
long stopTime = System.nanoTime();
long elapsedTime = stopTime - startTime;
System.out.println("RandomCase: Tri en " + elapsedTime);
if (!arraySorted(nombres)) {
fail("Should not happen");
}
assertTrue(true);
}
@Test
public void testRapideWorstCase() {
initWorst();
long startTime = System.nanoTime();
triRapide(nombres);
long stopTime = System.nanoTime();
long elapsedTime = stopTime - startTime;
System.out.println("RandomCase: Tri en " + elapsedTime);
if (!arraySorted(nombres)) {
fail("Should not happen");
}
assertTrue(true);
}
@Test
public void testFusionRandomCase() {
initRandom();
long startTime = System.nanoTime();
triFusion(nombres);
long stopTime = System.nanoTime();
long elapsedTime = stopTime - startTime;
System.out.println("RandomFusionCase: Tri en " + elapsedTime);
if (!arraySorted(nombres)) {
fail("Should not happen");
}
assertTrue(true);
}
@Test
public void testQuicksort() {
long startTime = System.nanoTime();
triRapide(nombres) ;
long stopTime = System.nanoTime();
long elapsedTime = stopTime - startTime;
if (!arraySorted(nombres)) {
fail("Should not happen");
}
System.out.println("QuickSort_RandomCase: Tri en " + elapsedTime + " nanoseconds");
assertTrue(true);
}
}