Fix naming LinkList_sort
-> LinkListSort
(#3640)
This commit is contained in:
parent
1e16709680
commit
d88b70113f
@ -8,16 +8,18 @@ package com.thealgorithms.sorts;
|
||||
|
||||
import java.util.*;
|
||||
|
||||
public class LinkList_Sort {
|
||||
public class LinkListSort {
|
||||
|
||||
public static boolean isSorted(int p[], int option) {
|
||||
try (Scanner sc = new Scanner(System.in)) {}
|
||||
try (Scanner sc = new Scanner(System.in)) {
|
||||
}
|
||||
int a[] = p;
|
||||
// Array is taken as input from test class
|
||||
int b[] = p;
|
||||
// array similar to a
|
||||
int ch = option;
|
||||
// Choice is choosed as any number from 1 to 3 (So the linked list will be sorted by Merge sort technique/Insertion sort technique/Heap sort technique)
|
||||
// Choice is choosed as any number from 1 to 3 (So the linked list will be
|
||||
// sorted by Merge sort technique/Insertion sort technique/Heap sort technique)
|
||||
switch (ch) {
|
||||
case 1:
|
||||
Task nm = new Task();
|
||||
@ -26,10 +28,13 @@ public class LinkList_Sort {
|
||||
// New nodes are created and values are added
|
||||
fresh = new Node(); // Node class is called
|
||||
fresh.val = a[i]; // Node val is stored
|
||||
if (start == null) start = fresh; else prev.next = fresh;
|
||||
if (start == null)
|
||||
start = fresh;
|
||||
else
|
||||
prev.next = fresh;
|
||||
prev = fresh;
|
||||
}
|
||||
start = nm.sort_by_mergesort(start);
|
||||
start = nm.sortByMergeSort(start);
|
||||
// method is being called
|
||||
int i = 0;
|
||||
for (ptr = start; ptr != null; ptr = ptr.next) {
|
||||
@ -38,39 +43,43 @@ public class LinkList_Sort {
|
||||
}
|
||||
Arrays.sort(b);
|
||||
// array b is sorted and it will return true when checked with sorted list
|
||||
LinkList_Sort uu = new LinkList_Sort();
|
||||
LinkListSort uu = new LinkListSort();
|
||||
if (uu.compare(a, b)) {
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
// The given array and the expected array is checked if both are same then true is displayed else false is displayed
|
||||
// The given array and the expected array is checked if both are same then true
|
||||
// is displayed else false is displayed
|
||||
case 2:
|
||||
Node start1 = null, prev1 = null, fresh1, ptr1;
|
||||
for (int i1 = 0; i1 < a.length; i1++) {
|
||||
// New nodes are created and values are added
|
||||
fresh1 = new Node(); // New node is created
|
||||
fresh1.val = a[i1]; // Value is stored in the value part of the node
|
||||
if (start1 == null) start1 = fresh1; else prev1.next =
|
||||
fresh1;
|
||||
if (start1 == null)
|
||||
start1 = fresh1;
|
||||
else
|
||||
prev1.next = fresh1;
|
||||
prev1 = fresh1;
|
||||
}
|
||||
Task1 kk = new Task1();
|
||||
start1 = kk.sort_by_insertionsort(start1);
|
||||
start1 = kk.sortByInsertionSort(start1);
|
||||
// method is being called
|
||||
int i1 = 0;
|
||||
for (ptr1 = start1; ptr1 != null; ptr1 = ptr1.next) {
|
||||
a[i1++] = ptr1.val;
|
||||
// storing the sorted values in the array
|
||||
}
|
||||
LinkList_Sort uu1 = new LinkList_Sort();
|
||||
LinkListSort uu1 = new LinkListSort();
|
||||
// array b is not sorted and it will return false when checked with sorted list
|
||||
if (uu1.compare(a, b)) {
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
// The given array and the expected array is checked if both are same then true is displayed else false is displayed
|
||||
// The given array and the expected array is checked if both are same then true
|
||||
// is displayed else false is displayed
|
||||
case 3:
|
||||
Task2 mm = new Task2();
|
||||
Node start2 = null, prev2 = null, fresh2, ptr2;
|
||||
@ -78,11 +87,13 @@ public class LinkList_Sort {
|
||||
// New nodes are created and values are added
|
||||
fresh2 = new Node(); // Node class is created
|
||||
fresh2.val = a[i2]; // Value is stored in the value part of the Node
|
||||
if (start2 == null) start2 = fresh2; else prev2.next =
|
||||
fresh2;
|
||||
if (start2 == null)
|
||||
start2 = fresh2;
|
||||
else
|
||||
prev2.next = fresh2;
|
||||
prev2 = fresh2;
|
||||
}
|
||||
start2 = mm.sort_by_heapsort(start2);
|
||||
start2 = mm.sortByHeapSort(start2);
|
||||
// method is being called
|
||||
int i3 = 0;
|
||||
for (ptr2 = start2; ptr2 != null; ptr2 = ptr2.next) {
|
||||
@ -91,13 +102,14 @@ public class LinkList_Sort {
|
||||
}
|
||||
Arrays.sort(b);
|
||||
// array b is sorted and it will return true when checked with sorted list
|
||||
LinkList_Sort uu2 = new LinkList_Sort();
|
||||
LinkListSort uu2 = new LinkListSort();
|
||||
if (uu2.compare(a, b)) {
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
// The given array and the expected array is checked if both are same then true is displayed else false is displayed
|
||||
// The given array and the expected array is checked if both are same then true
|
||||
// is displayed else false is displayed
|
||||
default:
|
||||
// default is used incase user puts a unauthorized value
|
||||
System.out.println("Wrong choice");
|
||||
@ -108,10 +120,12 @@ public class LinkList_Sort {
|
||||
|
||||
boolean compare(int a[], int b[]) {
|
||||
for (int i = 0; i < a.length; i++) {
|
||||
if (a[i] != b[i]) return false;
|
||||
if (a[i] != b[i])
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
// Both the arrays are checked for equalness. If both are equal then true is returned else false is returned
|
||||
// Both the arrays are checked for equalness. If both are equal then true is
|
||||
// returned else false is returned
|
||||
}
|
||||
/**
|
||||
* OUTPUT :
|
||||
@ -137,8 +151,9 @@ class Task {
|
||||
|
||||
static int a[];
|
||||
|
||||
public Node sort_by_mergesort(Node head) {
|
||||
if (head == null || head.next == null) return head;
|
||||
public Node sortByMergeSort(Node head) {
|
||||
if (head == null || head.next == null)
|
||||
return head;
|
||||
int c = count(head);
|
||||
a = new int[c];
|
||||
// Array of size c is created
|
||||
@ -182,7 +197,10 @@ class Task {
|
||||
int i = s, k = 0, j = m + 1;
|
||||
int b[] = new int[e - s + 1];
|
||||
while (i <= m && j <= e) {
|
||||
if (n[j] >= n[i]) b[k++] = n[i++]; else b[k++] = n[j++];
|
||||
if (n[j] >= n[i])
|
||||
b[k++] = n[i++];
|
||||
else
|
||||
b[k++] = n[j++];
|
||||
}
|
||||
// Smallest number is stored after checking from both the arrays
|
||||
while (i <= m) {
|
||||
@ -200,8 +218,9 @@ class Task {
|
||||
|
||||
class Task1 {
|
||||
|
||||
public Node sort_by_insertionsort(Node head) {
|
||||
if (head == null || head.next == null) return head;
|
||||
public Node sortByInsertionSort(Node head) {
|
||||
if (head == null || head.next == null)
|
||||
return head;
|
||||
int c = count(head);
|
||||
int a[] = new int[c];
|
||||
// Array of size c is created
|
||||
@ -242,8 +261,9 @@ class Task2 {
|
||||
|
||||
static int a[];
|
||||
|
||||
public Node sort_by_heapsort(Node head) {
|
||||
if (head == null || head.next == null) return head;
|
||||
public Node sortByHeapSort(Node head) {
|
||||
if (head == null || head.next == null)
|
||||
return head;
|
||||
int c = count(head);
|
||||
a = new int[c];
|
||||
// Array of size c is created
|
||||
@ -290,8 +310,10 @@ class Task2 {
|
||||
int p = i;
|
||||
int l = 2 * i + 1;
|
||||
int r = 2 * i + 2;
|
||||
if (l < k && n[l] > n[p]) p = l;
|
||||
if (r < k && n[r] > n[p]) p = r;
|
||||
if (l < k && n[l] > n[p])
|
||||
p = l;
|
||||
if (r < k && n[r] > n[p])
|
||||
p = r;
|
||||
if (p != i) {
|
||||
int d = n[p];
|
||||
n[p] = n[i];
|
@ -2,7 +2,7 @@ package com.thealgorithms.others;
|
||||
|
||||
import static org.junit.jupiter.api.Assertions.*;
|
||||
|
||||
import com.thealgorithms.sorts.LinkList_Sort;
|
||||
import com.thealgorithms.sorts.LinkListSort;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
public class LinkListSortTest {
|
||||
@ -10,48 +10,48 @@ public class LinkListSortTest {
|
||||
@Test
|
||||
void testForOneElement() {
|
||||
int a[] = { 56 };
|
||||
assertTrue(LinkList_Sort.isSorted(a, 2));
|
||||
assertTrue(LinkListSort.isSorted(a, 2));
|
||||
}
|
||||
|
||||
@Test
|
||||
void testForTwoElements() {
|
||||
int a[] = { 6, 4 };
|
||||
assertTrue(LinkList_Sort.isSorted(a, 1));
|
||||
assertTrue(LinkListSort.isSorted(a, 1));
|
||||
}
|
||||
|
||||
@Test
|
||||
void testForThreeElements() {
|
||||
int a[] = { 875, 253, 12 };
|
||||
assertTrue(LinkList_Sort.isSorted(a, 3));
|
||||
assertTrue(LinkListSort.isSorted(a, 3));
|
||||
}
|
||||
|
||||
@Test
|
||||
void testForFourElements() {
|
||||
int a[] = { 86, 32, 87, 13 };
|
||||
assertTrue(LinkList_Sort.isSorted(a, 1));
|
||||
assertTrue(LinkListSort.isSorted(a, 1));
|
||||
}
|
||||
|
||||
@Test
|
||||
void testForFiveElements() {
|
||||
int a[] = { 6, 5, 3, 0, 9 };
|
||||
assertTrue(LinkList_Sort.isSorted(a, 1));
|
||||
assertTrue(LinkListSort.isSorted(a, 1));
|
||||
}
|
||||
|
||||
@Test
|
||||
void testForSixElements() {
|
||||
int a[] = { 9, 65, 432, 32, 47, 327 };
|
||||
assertTrue(LinkList_Sort.isSorted(a, 3));
|
||||
assertTrue(LinkListSort.isSorted(a, 3));
|
||||
}
|
||||
|
||||
@Test
|
||||
void testForSevenElements() {
|
||||
int a[] = { 6, 4, 2, 1, 3, 6, 7 };
|
||||
assertTrue(LinkList_Sort.isSorted(a, 1));
|
||||
assertTrue(LinkListSort.isSorted(a, 1));
|
||||
}
|
||||
|
||||
@Test
|
||||
void testForEightElements() {
|
||||
int a[] = { 123, 234, 145, 764, 322, 367, 768, 34 };
|
||||
assertTrue(LinkList_Sort.isSorted(a, 2));
|
||||
assertTrue(LinkListSort.isSorted(a, 2));
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user