import java.util.Scanner; public class PTA01 { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int n = Integer.parseInt(sc.nextLine()); String input = sc.nextLine(); String[] strarr = input.split(" "); int[] arr = new int[n]; for (int i = 0; i < n; i++) { arr[i] = Integer.parseInt(strarr[i]); } SeceltSort(arr); } public static void SeceltSort(int[] arr) { for (int i = 0; i < arr.length; i++) { int temp = arr[i]; int index = i; boolean flag = false; for (int j = i; j < arr.length; j++) { if (temp > arr[j]) { temp = arr[j]; index = j; flag = true; } } if (flag == false) continue; temp = arr[i]; arr[i] = arr[index]; arr[index] = temp; if(i!=0) System.out.println(); for (int a = 0; a < arr.length; a++) { System.out.print(arr[a]); if (a!=arr.length-1) System.out.print(" "); } } } }
时间: 2023-06-13 16:04:55 浏览: 121
这段代码实现的是选择排序,输入一个整数 n 和 n 个整数,然后对这 n 个整数进行选择排序并输出每次排序后的结果。
具体实现过程:
首先通过 Scanner 对象读取输入,第一行是整数 n,第二行是 n 个整数,用 split 方法将第二行的字符串按空格分割成整数数组。
然后调用 SeceltSort 方法进行选择排序,遍历数组,每次找到未排序部分的最小值,将其与未排序部分的第一个元素交换位置。在交换位置后,输出当前排序结果。
最后的输出结果类似于:
1 2 3 4 5
1 2 3 4 5
1 2 3 4 5
1 2 3 4 5
1 2 3 4 5
每行输出一个排序结果。
相关问题
package module4; import java.util.ArrayList; import java.util.Scanner; public class Test40 { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); ArrayList<Shape> list = new ArrayList<>(); … }
很抱歉,我不太明白您想要问什么问题。这段代码看起来像是Java语言中创建一个Test40类的程序,其中包含一个main方法,该方法利用Scanner类和ArrayList类实现对形状类Shape的动态数组进行输入和操作。您需要补充代码以实现完整的功能。如果您有任何具体的问题或需要帮助,请告诉我,我会尽力回答。
import java.util.Scanner; public class test01{ public static void main(String[] args){ Scanner myScanner = new Scanner(System.in); String name = myScanner.next(); System.out.println(name);} }
你好!你的代码看起来是一个简单的Java程序,它使用了Scanner类来获取用户输入的字符串,并将其打印出来。在这段代码中,你创建了一个Scanner对象myScanner,并使用next()方法获取用户输入的字符串,并将其存储在name变量中。最后,使用System.out.println()方法将name变量的值打印出来。
请问有什么其他问题我可以帮助你解答吗?
阅读全文