【Java】旋转NxN的矩阵90°
2015-07-07 21:36
741 查看
给定一个由NxN矩阵表示的图像,其中每个像素的大小为4个字节,编写一个方法,将图像旋转90°。不占用额外内存空间能否做到?
将矩阵旋转90°,第一个想到的做法就是一层一层进行旋转,将上边移到右边,右边移到下边,下边移到左边,左边移到上边。
那么如果要交换就是把上边复制到一个大小为N的数组中,然后将左边移到上边,下边移到左边,右边移到下边,等等。这样要占用的内存大小是O(N)。
实际上有一个更好的办法,是按照索引一个一个进行交换:for i = 0 to N
temp = top[i]
top[i] = left[i]
left[i] = bottom[i]
bottom[i] = right[i]
right[i] = temp从最外一层逐层向里,在每一层上执行上述交换,空间复杂度为1,时间复杂度为O(n2)
public class rotate {
public void rotate(int[][] matrix, int n)
{
for (int layer = 0; layer < n/2; layer++)
{
int first = layer;
int last = n-1-layer;
for (int i = first; i < last; i++)
{
int offset = i - first;
int top = matrix[first][i];
matrix[first][i] = matrix[last - offset][first];
matrix[last - offset][first] = matrix[last][last - offset];
matrix[last][last - offset] = matrix[i][last];
matrix[i][last] = top;
}
}
}
}
将矩阵旋转90°,第一个想到的做法就是一层一层进行旋转,将上边移到右边,右边移到下边,下边移到左边,左边移到上边。
那么如果要交换就是把上边复制到一个大小为N的数组中,然后将左边移到上边,下边移到左边,右边移到下边,等等。这样要占用的内存大小是O(N)。
实际上有一个更好的办法,是按照索引一个一个进行交换:for i = 0 to N
temp = top[i]
top[i] = left[i]
left[i] = bottom[i]
bottom[i] = right[i]
right[i] = temp从最外一层逐层向里,在每一层上执行上述交换,空间复杂度为1,时间复杂度为O(n2)
public class rotate {
public void rotate(int[][] matrix, int n)
{
for (int layer = 0; layer < n/2; layer++)
{
int first = layer;
int last = n-1-layer;
for (int i = first; i < last; i++)
{
int offset = i - first;
int top = matrix[first][i];
matrix[first][i] = matrix[last - offset][first];
matrix[last - offset][first] = matrix[last][last - offset];
matrix[last][last - offset] = matrix[i][last];
matrix[i][last] = top;
}
}
}
}
相关文章推荐
- springMVC学习笔记-请求处理&springMVC form标签
- Java开发中的23种设计模式详解
- Java 多线程
- JAVA 大数在acm中的应用(2)
- 一个Java解析JSON字符串的例子
- 一.Spring学习之旅----初识Spring
- Eclipse安装SVN插件
- 编写一个比较完美的equals方法的建议(java)
- java学习12--函数--函数定义和功能
- Rectangle Area
- Java数组练习题小结
- Java基础之多态性
- eclipse下给jar增加源代码
- 使用JAVA连接access 2003
- 将数字字符串转换为int型
- Java-ReentrantReadWriteLock的简单例子
- Java编程思想 - 类型信息与反射机制
- Java.lang.Long.parseLong()方法
- 【源代码】java.util.LinkedList
- MYSQY数据库类型与Java类型的对比图(收藏使用)