废话少说,直接上思路:
假设二维数据的长度为25,那结果大概如下图所示:
解题思路主要从这张下标示例图开始,来构造二维数组。构造结果应该如下图所示:
直接上代码:
public static int[][] creatArray(int length){
int count = 1;
int[][] array = new int[length][length];
for(int k=0,n=length;k<n;k++,n--){
//一横 [0,0] -> [0,4] 纵坐标在递增,所以变量i为纵坐标
// 由0至4结束,所以 k=<i<n
for(int i=k;i<n;i++){
array[k][i] = count++;
}
//二纵 [1,4] -> [4,4] 横坐标在递增,所以变量i为横坐标
// 由1至4结束,所以 k<i<n
for(int i=k+1;i<n;i++){
array[i][n-1]=count++;
}
//三横 [4,3] -> [4,0] 纵坐标在递减,所以变量i为纵坐标
// 由3至0结束,所以 k=<i<=n-2
for(int i=n-2;i>=k;i--){
array[n-1][i]=count++;
}
//四纵 [3,0] -> [1,0] 横坐标在递减,所以变量i为横坐标
// 由3至1结束,所以 k<i<=n-2
for(int i=n-2;i>k;i--){
array[i][k]=count++;
}
}
return array;
}
public static void main(String[] args){
int length = 5;
int[][] array= creatArray(5);
for(int i=0;i<length;i++){
for(int j=0;j<length;j++){
System.out.println(array[i][j]);
}
}
}