Итак, я пытаюсь перебрать все элементы в 2D-массиве, используя один цикл.
Вот где я:
public class Test {
private static final String[][] key = {
{"`", "1", "2", "3", "4", "5", "6", "7", "8", "9", "0", "-", "=", "Backspace"}, // 0 - 13
{"Tab", "Q", "W", "E", "R", "T", "Y", "U", "I", "O", "P", "[", "]", "\\"}, // 0 - 13
{"Caps", "A", "S", "D", "F", "G", "H", "J", "K", "L", ";", "'", "Enter"}, // 0 - 12
{"Shift", "Z", "X", "C", "V", "B", "N", "M", ",", ".", "/", "\u2191"}, // 0 - 11
{" ", "<", "\u2193", ">"} // 0 - 3
};
public static void main(String[] args) {
final int totalLen = 57;
String str = "";
for (int i = 0, row = 0, col = 0; i < totalLen; ++i, ++col) {
if (row < key.length && i % key[row].length >= key[row].length - 1) {
++row;
col = 0;
System.out.println(str);
str = "";
}
if (row < key.length)
str += col + " ";
}
}
}
Я прокомментировал диапазон индексов для каждой строки, которую должна вывести приведенная выше программа, но это не так, поскольку логика ошибочна. Какие-либо предложения?
Изменить: условие цикла должно оставаться прежним.
57
— это не магическое число, это общее количество элементов в массиве.i
используется как индекс для другого массива, который здесь не имеет значения. - person   schedule 13.07.2014