Я хочу отсортировать массив в соответствии со столбцами (в порядке возрастания). Метод sortByrollNum работает правильно. Но во втором методе sortByPer печатается наибольшее число сверху. Он должен печататься в порядке возрастания, как и первый метод.Я много пробовал. Может кто-нибудь помочь мне, как это исправить?
public static int compareStrings(String str1,String str2){
int check=str1.compareTo(str2);
return check;
}//RollNumCheck
public static void sortByRollNum(String [] [] arr,int currentSize){
String minName=arr[0][0];
String minRollNum=arr[0][1];
String minPer=arr[0][2];
for(int j=0;j<arr.length-1;j++){
for(int i=0;i<arr.length-j-1;i++){
int check=compareStrings(arr[i][1], arr[i+1][1]);
if(check>0){
minName=arr[i+1][0];
minRollNum=arr[i+1][1];
minPer=arr[i+1][2];
arr[i+1][0]=arr[i][0];
arr[i+1][1]=arr[i][1];
arr[i+1][2]=arr[i][2];
arr[i][0]=minName;
arr[i][1]=minRollNum;
arr[i][2]=minPer;
}//if
}//for
}//for
System.out.print("\nSorted Array according to Roll Number.\n");
printArray(arr);
}//sortByRollNum
public static void sortByPer(String [] [] arr,int currentSize){
String minName=arr[0][0];
String minRollNum=arr[0][1];
String minPer=arr[0][2];
for(int j=0;j<arr.length-1;j++){
for(int i=0;i<arr.length-j-1;i++){
int check=compareStrings(arr[i][2], arr[i+1][2]);
if(check>0){
minName=arr[i+1][0];
minRollNum=arr[i+1][1];
minPer=arr[i+1][2];
arr[i+1][0]=arr[i][0];
arr[i+1][1]=arr[i][1];
arr[i+1][2]=arr[i][2];
arr[i][0]=minName;
arr[i][1]=minRollNum;
arr[i][2]=minPer;
}//if
}//for
}//for
System.out.print("\nSorted Array according to Percentage.\n");
printArray(arr);
}//sortByPer