备忘小算法:Java将一维数组数据绘制成N行N列矩阵(如九宫格)
一个小算法的备忘:用Java将一维数组数据绘制成N行M列的矩阵。特别的,如果刚好9个数据,则列数即为3,行数即为3,那么就是典型的如九宫格。
package test;
public class Main {
// 如果列数是3列,那么就是九宫格样式。列数可以是其他值。
private static final int COLUMN = 3;
private static int[] test_data = { 1, 2, 3, 4, 5, 6, 7, 8, 9 };
public static void main(String[] args) {
int len = test_data.length;
// 计算给出的一维数组装载到COLUMN列数据后的总行数。
// 原理:首先进行模运算,
// 如果余数为0,则表明刚好凑成对齐的完整行列矩阵。
// 如果余数非0,则表明模运算结果之外,还有一行没凑完整,是一行残缺的行。加上它。
int mod = len % COLUMN;// Java模运算取余
int ROWS = 0;
if (mod == 0) {
ROWS = len / COLUMN;
} else
ROWS = len / COLUMN + 1;
int count = 0;// count是测试数组的下标,检测输出的位置。
// 逐行输出,每行输出COLUMN个数据后换行。
for (int i = 0; i < ROWS; i++) {
for (int j = 0; j < COLUMN && (count < len); j++) {
System.out.print(test_data[count] + " ");
count++;
}
// 换行符
System.out.println();
}
}
}
输出结果:
1 2 3
4 5 6
7 8 9