public class Solution {
public static int[][] rotate(int[][] matrix, int flag)
{
if(matrix == null || matrix.length == 0) return matrix;
int m = matrix.length, n = matrix[0].length;
int[][] res = new int[n][m];
for(int i = 0; i < m; i++)
{
for(int j = 0; j < n; j++) res[j][i] = matrix[i][j];
}
if(flag == 1)
{
for(int i = 0; i < n; i++)
{
for(int j = 0; j < m / 2; j++)
{
int tmp = res[i][j];
res[i][j] = res[i][m - 1 - j];
res[i][m - 1 - j] = tmp;
}
}
}
else
{
for(int j = 0; j < m ;j++)
{
for(int i = 0; i < n / 2; i++)
{
int tmp = res[i][j];
res[i][j] = res[n - 1 - i][j];
res[n - 1 - i][j] = tmp;
}
}
}
return res;
}
public static void printMatrix(int[][] matrix)
{
int m = matrix.length, n = matrix[0].length;
for(int i = 0; i < m; i++)
{
for(int j = 0; j < n; j++) System.out.print(matrix[i][j] + " ");
System.out.println("");
}
}
public static void main(String[] args)
{
int[][] input = {{1, 2, 3}, {4, 5, 6}, {7, 8, 9}};
int[][] output1 = rotate(input, 0);
int[][] output2 = rotate(input, 1);
System.out.println("input");
printMatrix(input);
System.out.println("output1");
printMatrix(output1);
System.out.println("output2");
printMatrix(output2);
}
}
Rotate Matrix
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- Android使用OpenGL ES2.0绘制3D图像或者加载3D模型时,为了达到立体效果往往需要设置视见转换矩阵...
- 转自竹音林,只为自己笔记,以备不时之需如果使用$(objName).css('transform')来获取CSS3...
- MF的主要思想其实就是假设,我们有N个用户,M个items,我们正常会有一个M*N的评分矩阵,然而这个矩阵可能...
- Scipy中常见的几类矩阵,包括lil_matrix和csc_matrix、coo_matrix,最近在研究网络结...