Java Selection Sorting Arrays in Java

AI Thread Summary
The discussion centers on implementing a selection sort algorithm within a Java program that creates an array of 20 integers, prompts the user to fill it, and then sorts the values from smallest to largest. The original code initializes the array and collects user input, but the user is unsure how to incorporate the provided selection sort methods. The solution involves either copying the sorting methods into the existing class, allowing direct calls within the main method, or placing them in a separate class (e.g., SelectionSort) and calling the sorting method using the class name. The correct syntax for invoking the sorting method is clarified, emphasizing the simplicity of the implementation once the methods are correctly positioned.
blue_soda025
Messages
26
Reaction score
0
So, I have to create a program that makes a new array with 20 slots, then it asks you to enter a value into each index, which I have here:

Code:
import java.io.*;

class ArrayLoop
{
	public static void main (String[] args) throws IOException
	{
		int[] array = new int[20];
		
		for (int i = 0; i <= 19; i++)
		{
			System.out.println("Assign a value to slot " + i + ".");
			array[i] = KeyIn.anInt();
		}
		
		System.out.println();
		System.out.println("The values are: ");
		for (int j = 0; j <= 19; j++)
		{
			System.out.print(array[j] + " ");
		}
	}
}

Except I have to make it so that it sorts each value from smallest to largest and print that out in the last line. I'm supposed to use selection sort for this and I'm given the code:

Code:
static void selection_sort(int a[])
{
	int i, min;
	for (i = 0; i < a.length; i++)
	{
		min = find_minimum(a, i);
		swap(a, i, min);
	}
}

static int find_minimum (int a[], int i)
{
	int j; min = i;
	for (j = i + 1; j < a.length; j++)
	if (a[j] < a[min])
	min = j;
	return min;
}

static void swap(int a[], int i, int j)
{
	int hold = a[i];
	a[i] = a[j];
	a[j] = hold;
}

The problem is, I have no idea how to implement this code to my original program :/. So the question is, how do I use selection sort in that program? Any help would be appreciated.
 
Technology news on Phys.org
Copy and paste them into your class ArrayLoop and then because the methods are static you can just use the method selection_sort on your array.
 
What would be the correct syntax for using the method on the array? I can't seem to get this to work.
 
blue_soda025 said:
What would be the correct syntax for using the method on the array? I can't seem to get this to work.

It depends where you put methods selection_sort(), find_minimum(), and swap().
One way (that I wouldn't suggest) is to put those methods in your class ArrayLoop (copy and paste), parallel with the main() method. Then you could just write inside main:

Code:
selection_sort( array );

The other way is to put those methods in another class (say, SelectionSort). Then inside main you would write:

Code:
SelectionSort.selection_sort( array );

It's that simple!
 
Oh, I see now. Thanks a lot.
 
Thread 'Star maps using Blender'
Blender just recently dropped a new version, 4.5(with 5.0 on the horizon), and within it was a new feature for which I immediately thought of a use for. The new feature was a .csv importer for Geometry nodes. Geometry nodes are a method of modelling that uses a node tree to create 3D models which offers more flexibility than straight modeling does. The .csv importer node allows you to bring in a .csv file and use the data in it to control aspects of your model. So for example, if you...
I tried a web search "the loss of programming ", and found an article saying that all aspects of writing, developing, and testing software programs will one day all be handled through artificial intelligence. One must wonder then, who is responsible. WHO is responsible for any problems, bugs, deficiencies, or whatever malfunctions which the programs make their users endure? Things may work wrong however the "wrong" happens. AI needs to fix the problems for the users. Any way to...

Similar threads

Back
Top