Das Beispiel in diesem Artikel beschreibt den Vorgang des Drehens eines zweidimensionalen Arrays in Java und wird als Referenz für alle freigegeben. Die spezifische Implementierungsmethode ist wie folgt:
Kopieren Sie den Codecode wie folgt:
Pakettest;
/*
* 1 2 3 4 5
* 16 17 18 19 6
* 15 24 25 20 7
* 14 23 22 21 8
* 13 12 11 10 9
*
* Schreiben Sie eine Methode zum Drucken eines zweidimensionalen Arrays gleicher Länge, bei der die natürlichen Zahlen beginnend bei 1 spiralförmig vom äußersten Kreis der quadratischen Matrix nach innen angeordnet werden müssen.
* */
öffentliche Klasse Test6
{
public static void main(String[] args)
{
arraynum(4);
}
// Es ist einfach, den Code zu ändern. Geben Sie verschiedene y-Werte ein und geben Sie verschiedene zweidimensionale Arrays aus.
private static void arraynum(int x)
{
int[][] arr = new int[x][x];
int len = arr.length, max = 0, count = 0;
specArr(arr, len, max, count);
arrprint(arr);
}
// Wird für den erweiterten Ausgabedruck verwendet
private static void arrprint(int[][] arr)
{
for (int[] in: arr)
{
for (int t : in)
{
System.out.print(t + "/t");
}
System.out.println();
}
}
private static void specArr(int[][] arr, int len, int max, int count)
{
while (len > 0)
{
int j = 0;
for (int index = 0; index < (len - 1) * 4; index++)
{
if (index < len - 1)
arr[0 + count][index + count] = ++max;
sonst wenn (index < 2 * (len - 1))
arr[count + j++][arr.length - 1 - count] = ++max;
sonst wenn (index < 3 * (len - 1))
arr[arr.length - 1 - count][(j--) + count] = ++max;
sonst wenn (index < 4 * (len - 1))
arr[arr.length - 1 - (j++) - count][0 + count] = ++max;
}
if (len == 1)
{
arr[arr.length / 2][arr.length / 2] = max + 1;
}// Beachten Sie, dass es eine Schleife zu n=1 gibt, wenn der y-Wert eine ungerade Zahl ist und der mittlere Wert des Arrays ergänzt werden muss.
count++;
len = len - 2;
}
}
}
Ich hoffe, dass dieser Artikel für die Java-Programmierung aller hilfreich sein wird.