Как манипулировать массивом, похожим на предложение ORDER BY в SQL? - PullRequest
1 голос
/ 17 февраля 2010

Мои данные были помещены в массив, но, к сожалению, не в том порядке, в котором я хочу их видеть ...

String[][] databaseToArray = {
  //{"Name", "Channel", "Description", "Amount", "isReady"},
    {"John", "Nick",    "likes",       "2",      "yes"    },
    {"Drew", "MTV",     "dislikes",    "4",      "no"     },
    {"Fred", "CNN",     "okay",        "3",      "no"     },
    {"Beth", "Fox",     "valid",       "1",      "yes"    }
};

Как мне манипулировать этим массивом, чтобы при циклическом цикле егона сумму, аналогичную SELECT * FROM "databaseToArray" ORDER BY "Amount" ака

String[][] reorganizedArray = {
  //{"Name", "Channel", "Description", "Amount", "isReady"},
    {"Beth", "Fox",     "valid",       "1",      "yes"    },
    {"John", "Nick",    "likes",       "2",      "yes"    },
    {"Fred", "CNN",     "okay",        "3",      "no"     },
    {"Drew", "MTV",     "dislikes",    "4",      "no"     }
};

Ответы [ 2 ]

2 голосов
/ 17 февраля 2010

Вы хотите передать Comparator в метод Arrays.sort.Я не занимался Java уже 5 лет, но это должно быть легко выполнимо.Может быть, кто-то может привести в порядок этот пример, который я собираюсь написать, поскольку я почти уверен, что что-то не так.

String[][] databaseToArray = {
  //{"Name", "Channel", "Description", "Amount", "isReady"},
    {"John", "Nick",    "likes",       "2",      "yes"    },
    {"Drew", "MTV",     "dislikes",    "4",      "no"     },
    {"Fred", "CNN",     "okay",        "3",      "no"     },
    {"Beth", "Fox",     "valid",       "1",      "yes"    }
};

Arrays.sort(databaseToArray, new Comparator<String[]>() {
    public int compare(String[] a, String[] b) {
        return a[3].compareTo(b[3]);
    }
});
0 голосов
/ 17 февраля 2010

Я нашел метод сортировки на веб-сайте обработки, но это только для одномерных массивов ...

http://processing.org/reference/sort_.html

   float[] a = { 3, 5, 2, 4, 1 };
   a = sort(a);
   println(a);
// Prints 1, 2, 3, 4, 5
...