数组是一种线性数据结构,用于存储一组具有相似数据类型的元素。它以顺序方式存储数据。一旦我们创建了一个数组,我们就不能改变它的大小,即它是固定长度的。
假设我们有一个 M x M 阶的二维数组,其中 M 是行数和列数。我们必须对给定数组的指定列进行排序。在本文中,我们将尝试找到给定问题的解决方案。
排序是指按升序或降序重新排列给定列表或数组的元素。让我们通过以下直观表示来了解什么是排序 -
当我们对该二维数组的第一列进行排序时 -

// declaration with size
Data_Type nameOfarray[][] = new Data_Type[sizeofrow][sizeofcolumn];
Or,
// declaration and initialization
Data_Type nameOfarray[][] = { {values separated by comma} };
我们可以在我们的程序中使用上述任何语法。
立即学习“Java免费学习笔记(深入)”;
在Data_Type 的位置, 我们可以给出原始数据类型,如 int 和 double。 Row 和 Column 是所需的数组大小。
在进入程序之前,让我们再讨论一件事。
Java 提供了一个名为 sort() 的内置方法,可以按自然顺序对数组和集合进行排序。 Comparator是一个通用接口,当我们需要以自定义方式对元素进行排序时可以使用它,基本上,我们可以控制排序的顺序。该接口定义了一个方法‘compare()’,它接受两个参数并比较它们。当两个参数相等时返回 0,如果第一个参数大于第二个参数则返回正值,否则返回负值。
Comparator<typeOfelement> nameOfcollection = new Comaprator<typeOfelement>() {
// your code here
};
步骤 1 - 在类“Srt”中定义方法“araySort()”以及两个参数。在此方法中,创建 Comparator 接口“comp”的对象。现在,定义比较方法,该方法将两行数组一起作为参数。
第 2 步 - 进一步,我们将采用 if-else 块来比较指定的列值,如果第一列的元素大于第二列,则返回 1,否则返回 -1 .
第 3 步 - 现在,使用“Arrays.sort()”方法对数组进行排序。
第 4 步 - 使用两个 for 循环来打印新的排序数组。
第 5 步 - 最后,在 main() 方法中,我们将声明并初始化一个数组。继续创建“Srt”类的对象,以“aray”和列索引作为参数调用方法“araySort()”。
import java.util.*;
class Srt {
void araySort(int aray[][], int cl) {
Comparator<int[]> comp = new Comparator<int[]>() {
public int compare(int[] val1, int[] val2) {
if(val1[cl-1] > val2[cl-1]) {
return 1;
} else {
return -1;
}
}
};
Arrays.sort(aray, comp);
System.out.println("The sorted array: ");
for(int i = 0; i< aray.length; i++) {
for (int j = 0; j < aray[i].length; j++) {
System.out.print(aray[i][j] + " ");
}
System.out.println();
}
}
}
public class Sorting {
public static void main(String[] args) {
int aray[][] = { { 7, 2, 1, 3 }, { 6, 1, 3, 7 }, { 4, 9, 8, 0 }, { 8, 0, 1, 2 } };
System.out.println("The given array we have: ");
// for each loop to print original 2D array
for (int[] array : aray) {
for (int print : array) {
System.out.print(print + " ");
}
System.out.println();
}
Srt obj = new Srt();
// calling method using object
obj.araySort(aray, 1);
obj.araySort(aray, 3);
}
}
The given array we have: 7 2 1 3 6 1 3 7 4 9 8 0 8 0 1 2 The sorted array: 4 9 8 0 6 1 3 7 7 2 1 3 8 0 1 2 The sorted array: 8 0 1 2 7 2 1 3 6 1 3 7 4 9 8 0
二维数组是具有行和列的数组。在本文中,我们创建了一个 Java 程序来根据指定列的值对二维数组进行排序。我们了解了如何使用 Comparator 接口的内置方法“compare()”对数组或集合进行排序。
以上就是在Java中根据任意给定列中的值对2D数组进行排序的详细内容,更多请关注php中文网其它相关文章!
java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号