この記事の例は、Java で 2 次元配列を回転する操作を説明しており、参考のために皆さんに共有されています。具体的な実装方法は以下の通りです。
次のようにコードをコピーします。
パッケージテスト。
/*
* 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
*
* 正方行列の最外周の円から内側に向かって 1 から始まる自然数を螺旋状に並べて、等しい長さの 2 次元配列を出力するメソッドを記述してください。
* */
パブリッククラス Test6
{
public static void main(String[] args)
{
配列番号(4);
}
// コードを変更するのは簡単です。異なる y 値を入力して、異なる 2 次元配列を出力します。
プライベート静的無効配列番号(int x)
{
int[][] arr = 新しい int[x][x];
int len = arr.length、max = 0、count = 0;
specArr(arr, len, max, count);
arrprint(arr);
}
// 出力印刷用のアドバンストに使用されます
private static void arrprint(int[][] arr)
{
for (int[] in : arr)
{
for (int : 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 インデックス = 0; インデックス < (len - 1) * 4; インデックス++)
{
if (インデックス < len - 1)
arr[0 + カウント][インデックス + カウント] = ++max;
else if (インデックス < 2 * (len - 1))
arr[カウント + j++][arr.length - 1 - カウント] = ++max;
else if (インデックス < 3 * (len - 1))
arr[arr.length - 1 - count][(j--) + count] = ++max;
else if (インデックス < 4 * (len - 1))
arr[arr.length - 1 - (j++) - count][0 + count] = ++max;
}
if (レン == 1)
{
arr[arr.length / 2][arr.length / 2] = 最大 + 1;
}// y の値が奇数の場合、n=1 へのループが発生し、配列の中央の値を補足する必要があることに注意してください。
カウント++;
レン = レン - 2;
}
}
}
この記事が皆さんの Java プログラミングに役立つことを願っています。