首页 > Java > java教程 > 正文

Java 中的二维数组排序

WBOY
发布: 2024-08-30 15:27:29
原创
1185 人浏览过

以下文章提供了 Java 中的 2D 数组排序的概述。数组的数组可以是二维数组。组成二维数组的矩阵表示行和列的集合。因为 2D 数组的元素可以随机访问,所以我们可以使用索引访问 2D 数组中的各个单元,就像使用一维数组一样。

广告 该类别中的热门课程 JAVA 掌握 - 专业化 | 78 课程系列 | 15 次模拟测试

在二维数组中,单元格有两个索引,一个是行号,另一个是列号。排序是一种按特定顺序排列二维数组中元素的技术。二维数组可以按升序或降序排列。让我们看看如何在 Java 中以不同的方式对二维数组进行升序和降序排序。

Java 中二维数组排序的示例

不同的例子如下:

示例#1

Java 中的 2D 数组排序示例,用于对 2D 数组的所有元素进行排序。

代码:

package jex;
import java.util.*;
public class demo {
// using bubble sort to sort 2D array
// sort 2D array same as it is in a 1D array of size n * m
public static void sort(int arr[][]) {
int i, j, temp;
int n=arr.length;
int m=arr[0].length;
for (i = 0; i < n * m - 1; ++i) {
for (j = 0; j < n * m - 1 - i; ++j) {
if (arr[j / m][j % m] > arr[(j + 1) / m][(j + 1) % m]) {
temp = arr[(j + 1) / m][(j + 1) % m];
arr[(j + 1) / m][(j + 1) % m] = arr[j / m][j % m];
arr[j / m][j % m] = temp;
}
}
}
}
public static void print(int arr[][]) {
int i, j;
int n=arr.length;
int m=arr[0].length;
for (i = 0; i < n; ++i) {
for (j = 0; j < m; ++j) {
System.out.print(arr[i][j]+" ");
}
System.out.println();
}
}
public static void main(String[] args)
{
Scanner sc=new Scanner(System.in);
int[][] arr={ { 5, 12, 17, 12, 23},
{ 1, 2, 4, 6, 8},
{21, 14, 7, 19, 27},
{ 3, 18, 9, 15, 25}
};
System.out.println("Array Before Sorting is : ");
print(arr);
sort(arr);
System.out.println("Array After Sorting is : ");
print(arr);
}
}
登录后复制

输出:

Java 中的二维数组排序

如上面的程序所示,sort() 方法可用于迭代二维数组的每个元素,并且当当前元素大于下一个元素时,则交换数字。最后,打印方法显示二维数组的所有元素。在 main 函数中,在调用 sort() 函数之后和之前创建并打印二维数组,如上面的输出所示。

示例#2

Java 中的 2D 数组排序示例,按列对 2D 数组的所有元素进行排序。

代码:

package jex;
import java.util.*;
public class demo {
public static void sort(int arr[][]) {
int i, j,k, temp;
int n=arr.length;
int m=arr[0].length;
for (k = 0; k < m; ++k) {
for (i = 0; i < n; ++i) {
for (j = 0; j < n - 1 - i; ++j) {
if (arr[j][k] > arr[j + 1][k]) {
temp = arr[j + 1][k];
arr[j + 1][k] = arr[j][k];
arr[j][k] = temp;
}
}
}
}
}
public static void print(int arr[][]) {
int i, j;
int n=arr.length;
int m=arr[0].length;
for (i = 0; i < n; ++i) {
for (j = 0; j < m; ++j) {
System.out.print(arr[i][j]+" ");
}
System.out.println();
}
}
public static void main(String[] args)
{
Scanner sc=new Scanner(System.in);
int[][] arr={ { 5, 12, 17, 12, 23},
{ 1, 2, 4, 6, 8},
{21, 14, 7, 19, 27},
{ 3, 18, 9, 15, 25}
};
System.out.println("Array Before Sorting is : ");
print(arr);
sort(arr);
System.out.println("Array After Sorting is : ");
print(arr);
}
}
登录后复制

输出:

Java 中的二维数组排序

与上面的重写程序一样,sort() 方法可用于迭代 2D 数组的每个元素并按列对数组进行排序。最后,打印方法显示二维数组的所有元素。在 main 函数中,在调用 sort() 函数之后和之前创建并打印二维数组,如上面的输出所示。

示例 #3

按行对二维数组的所有元素进行排序。

代码:

package jex;
import java.util.*;
public class demo {
// using bubble sort to sort 2D array
// sort 2D array same as it is in a 1D array of size n * m
public static void sort(int arr[][]) {
int i, j,k, temp;
int n=arr.length;
int m=arr[0].length;
for(k=0;k<n;++k){
// applying bubble sort on kth row
for(i=0;i<m;++i){
for(j=0;j<m-1-i;++j){
if(arr[k][j]>arr[k][j+1]){
temp = arr[k][j+1];
arr[k][j+1] = arr[k][j];
arr[k][j] = temp;
}
}
}
}
}
public static void print(int arr[][]) {
int i, j;
int n=arr.length;
int m=arr[0].length;
for (i = 0; i < n; ++i) {
for (j = 0; j < m; ++j) {
System.out.print(arr[i][j]+" ");
}
System.out.println();
}
}
public static void main(String[] args)
{
Scanner sc=new Scanner(System.in);
int[][] arr={ { 5, 12, 17, 12, 23},
{ 1, 2, 4, 6, 8},
{21, 14, 7, 19, 27},
{ 3, 18, 9, 15, 25}
};
System.out.println("Array Before Sorting is : ");
print(arr);
sort(arr);
System.out.println("Array After Sorting is : ");
print(arr);
}
}
登录后复制

输出:

Java 中的二维数组排序

与上面的重写程序一样,sort() 方法可用于迭代 2D 数组的每个元素并按行对数组进行排序。最后,打印方法显示二维数组的所有元素。在 main 函数中,在调用 sort() 函数之后和之前创建并打印二维数组,如上面的输出所示。

结论

排序是一种按特定顺序排列 2D 数组中元素的技术。例如,在二维数组中,一个单元格有两个索引:行号和列号。

以上是Java 中的二维数组排序的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:php
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!