当前位置: 首页 > wzjs >正文

国内视频网站域名网站优化排名金苹果系统

国内视频网站域名,网站优化排名金苹果系统,旅游景区网站建设方案文档,网站开发相关的教材书籍目录 旋转矩阵90度(原地操作)1. 题目2. 解释3. 思路4. 代码5. 总结6. 其他 旋转矩阵90度(原地操作) 1. 题目 旋转矩阵90度,且只能用有限的几个变量。比如下面的矩阵: 1 2 3 4 5 6 7 8 9 10 11 …

目录

  • 旋转矩阵90度(原地操作)
    • 1. 题目
    • 2. 解释
    • 3. 思路
    • 4. 代码
    • 5. 总结
    • 6. 其他

旋转矩阵90度(原地操作)

1. 题目

旋转矩阵90度,且只能用有限的几个变量。比如下面的矩阵:

1  2  3  4 
5  6  7  8 
9  10 11 12 
13 14 15 16 

转换结果为:

13 9  5  1 
14 10 6  2 
15 11 7  3 
16 12 8  4 

2. 解释

旋转矩阵90度是指将矩阵顺时针旋转90度。观察旋转前后的变化可以发现:

  1. 原矩阵的第一行变为旋转后矩阵的最后一列
  2. 原矩阵的第二行变为旋转后矩阵的倒数第二列
  3. 以此类推,原矩阵的第i行变为旋转后矩阵的第(n-i+1)列

要实现原地旋转(不额外使用O(n²)空间),可以通过以下两步完成:

  1. 先转置矩阵(行列互换)
  2. 然后反转每一行的元素

3. 思路

具体实现步骤:

  1. 转置矩阵:对于n×n矩阵,将matrix[i][j]与matrix[j][i]交换
  2. 反转每一行:将每一行的元素顺序反转
  3. 这样组合起来就实现了顺时针90度旋转

例如:

原矩阵:
1 2 3
4 5 6
7 8 9转置后:
1 4 7
2 5 8
3 6 9反转每行后:
7 4 1
8 5 2
9 6 3

4. 代码

public class RotateMatrix {public static void rotate(int[][] matrix) {int n = matrix.length;// 第一步:转置矩阵for (int i = 0; i < n; i++) {for (int j = i; j < n; j++) {int temp = matrix[i][j];matrix[i][j] = matrix[j][i];matrix[j][i] = temp;}}// 第二步:反转每一行for (int i = 0; i < n; i++) {for (int j = 0; j < n / 2; j++) {int temp = matrix[i][j];matrix[i][j] = matrix[i][n - 1 - j];matrix[i][n - 1 - j] = temp;}}}public static void printMatrix(int[][] matrix) {for (int[] row : matrix) {for (int num : row) {System.out.print(num + " ");}System.out.println();}}public static void main(String[] args) {int[][] matrix = {{1, 2, 3, 4},{5, 6, 7, 8},{9, 10, 11, 12},{13, 14, 15, 16}};System.out.println("原矩阵:");printMatrix(matrix);rotate(matrix);System.out.println("\n旋转后矩阵:");printMatrix(matrix);}
}

5. 总结

旋转矩阵90度的关键点:

  1. 原地旋转:通过转置+反转的方式实现,空间复杂度为O(1)
  2. 时间复杂度:O(n²),因为需要访问每个元素一次
  3. 适用场景:适用于n×n的方阵,对于非方阵需要不同的处理方式
  4. 扩展思考
    • 逆时针旋转90度可以先反转每行再转置
    • 旋转180度可以转置+反转两次

这种方法在图像处理、计算机图形学等领域有广泛应用,掌握这种矩阵操作技巧对解决相关问题很有帮助。

6. 其他

针对这个矩阵还有其他的方式,可以参考我之前的一个文章
左神算法之螺旋打印

public class Problem03_RotateMatrix {// 缩小范围public static void rotateMatrix(int[][] matrix) {int tR = 0;int tC = 0;int dR = matrix.length - 1;int dC = matrix[0].length - 1;while(tR <= dR) {rotateLevel(matrix, tR++, tC++, dR--, dC--);}}// 进行交换public static void rotateLevel(int[][] matrix, int a, int b, int c, int d) {int temp = 0;for(int i = 0; i < d - b; i++) {temp = matrix[a][b + i];matrix[a][b + i] = matrix[c - i][b];matrix[c - i][b] = matrix[c][d - i];matrix[c][d - i] = matrix[a + i][d];matrix[a + i][d] = temp;}}// 输出public static void printMatrix(int[][] matrix) {for(int i = 0; i < matrix.length; i++) {for(int j = 0; j < matrix[0].length; j++) {System.out.print(matrix[i][j] + " ");}System.out.println();}}public static void main(String[] args) {int[][] matrix = {{1, 2, 3, 4}, {5, 6, 7, 8}, {9, 10, 11, 12}, {13, 14, 15, 16}};printMatrix(matrix);rotateMatrix(matrix);System.out.println("===========================");printMatrix(matrix);}
}
http://www.dtcms.com/wzjs/423837.html

相关文章:

  • 怎么做自己的淘宝客推广网站郑州网站建设哪里好
  • 泰安网站建设找工作seo网址
  • 公司网站url北京网站优化seo
  • 如何在个人网上建网站天津做网站的公司
  • 做饰品网站接广告的网站
  • 风景区网站代码百度账号登录
  • 深圳网站优化网站关键词快速排名工具
  • 代码素材网站最新seo网站优化教程
  • 万江网站建设今日国际新闻热点
  • 网站开发的目标浙江seo公司
  • 网站设计费用一览表seo网站建设优化
  • 个人网站 建设百度竞价什么时候开始的
  • 西宁做手机网站的公司免费舆情监测平台
  • 知名网站建设官网营销策略有哪些
  • 外贸购物网站建设域名注册商怎么查
  • 北京h5网站建设平台成都网站建设软件
  • 学做网站的网站搜索排名广告营销
  • 智能网站平台百度推广代理商有哪些
  • 有口碑的赣州网站建设百度网盘app手机版
  • 做网站背景的图片网站优化外包价格
  • 山东商祺网站建设优化友情链接系统
  • 建一个网站需要多少钱上海关键词优化排名软件
  • 网站怎么做分页it培训机构学费一般多少
  • 专业网站制作价格搜索引擎营销的基本方法
  • 群辉 wordpress 端口seo优化一般包括哪些内容
  • 海盐网站建设濮阳市网站建设
  • 沂源手机网站建设公司已备案域名购买平台
  • 用html做网站搜索框静态网页设计与制作
  • 用心做的网站bing搜索国内版
  • 免费文档模板网站淘宝运营培训多少钱