思路:

 * 每个元素转置前后会形成一个环(一个数字有多个环)

 * 利用环来移动元素达到转置

 * 关键:

 * 1.得到元素下标的前驱后继,

 * 2.判断环是否已走过(意味属于一个环的元素一次转置完成)

 * 解决:

 * 1.从一维下标转二维坐标得到转置后的二维坐标再换回一维坐标

 * 如:M*N矩阵

 * 假设转置前某个元素的数组下标为i,则它所在行列为(i/N, i%N),

 * 转置后所在行列则为(i%N, i/N),可计算转置后数组下标为(i%N)*M+i/N,

 * 此为i的后继。假设转置后某个元素的数组下标为i,则它所在行列为(i/M, i%M),

 * 则转置前所在行列为(i%M, i/M),可计算此时下标为(i%M)*N+i/M,此为i的前驱。

 *

* 2.从一个下标开始直到回到自身没有出现比它小的下标,则环没走过

  1. #include <iostream>
  2. using namespace std;
  3.  
  4. #define M 4
  5. #define N 2
  6.  
  7. int getPrev(int i, int m, int n) {
  8. return (i % M) * N + i / M;
  9. }
  10.  
  11. int getNext(int i, int m, int n) {
  12. return (i % N) * M + i / N;
  13. }
  14.  
  15. void moveData(int* arr, int i) {
  16. int cur = i;
  17. int temp = arr[i];
  18. int prev = getPrev(i, M, N);
  19. while (prev != i) {
  20. arr[cur] = arr[prev];
  21. cur = prev;
  22. prev = getPrev(cur, M, N);
  23. }
  24. arr[cur] = temp;
  25. }
  26.  
  27. void transfer(int* arr, int m, int n) {
  28. for (int i = 0; i < m * n; ++i) {
  29. int next = getNext(i, m, n);
  30. while (i < next) {
  31. next = getNext(next, m, n);
  32. }
  33. //环未走过
  34. if (i == next) {
  35. moveData(arr, i);
  36. }
  37. }
  38. }
  39.  
  40. void printMatrix(int* matrix, int m, int n) {
  41. for (int i = 0; i < m; ++i) {
  42. for (int j = 0; j < n; ++j) {
  43. cout << matrix[i * n + j] << " ";
  44. }
  45. cout << endl;
  46. }
  47. }

O(1)空间内实现矩阵转置的更多相关文章

  1. 矩阵转置 O(1)空间

    题目:用O(1)的空间实现矩阵的转置 为了方便,使用一维数组来分析.所谓矩阵转置,行变列,列变行.在转置的过程中,有的元素位置是不变的:对于变化位置的元素,要求O(1)空间完成,那么这些位置的变化一定 ...

  2. opencv、numpy中矩阵转置,矩阵内的固定位置相应的坐标变换

    opencv.numpy中矩阵转置,矩阵内的固定位置相应的坐标变换

  3. Python小代码_5_二维矩阵转置

    使用列表推导式实现二维矩阵转置 matrix = [[1, 2, 3, 4], [5, 6, 7, 8], [9, 10, 11, 12]] print(matrix) matrix_t = [[ro ...

  4. SDUT-2130_数据结构实验之数组一:矩阵转置

    数据结构实验之数组一:矩阵转置 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 数组--矩阵的转置 给定一个m*n的矩阵 ...

  5. 求空间内两条直线的最近距离以及最近点的坐标(C++)

    关键词:空间几何 用途:总有地方会用到吧 文章类型:C++函数展示 @Author:VShawn(singlex@foxmail.com) @Date:2016-11-19 @Lab: CvLab20 ...

  6. <矩阵的基本操作:矩阵相加,矩阵相乘,矩阵转置>

    //矩阵的基本操作:矩阵相加,矩阵相乘,矩阵转置 #include<stdio.h> #include<stdlib.h> #define M 2 #define N 3 #d ...

  7. 【异构计算】OpenCL矩阵转置

    介绍 矩阵转置,主要的技巧还是利用好local memory ,防止local memory,以及glabol memory的读取尽量是合并读写. 完整代码一: main.cpp代码 #include ...

  8. [转]Python中的矩阵转置

    Python中的矩阵转置 via 需求: 你需要转置一个二维数组,将行列互换. 讨论: 你需要确保该数组的行列数都是相同的.比如: arr = [[1, 2, 3], [4, 5, 6], [7, 8 ...

  9. [置顶] [MATLAB技术贴]漫谈MATLAB矩阵转置

    矩阵转置是matlab最基本的操作了,但这个基本操作,也是很多初学者容易出现问题的地方.本帖通过几个实例演示matlab矩阵转置的操作. 方法一:'  运算符与  .'  运算符 >>a ...

随机推荐

  1. hdu1060 Leftmost Digit---求N的N次方的首位(对数)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1060 题目描述:求N的N次方的第一位. 思路: 第一次做这种类型的题目,学到了如何运用对数. 首先推 ...

  2. Delphi X10.2 + FireDAC 使用 SQL 语句 UPDATE

    MainForm.Conn.StartTransaction; UserManagerQuery.SQL.Clear; UserManagerQuery.SQL.Text := 'UPDATE tab ...

  3. Ubuntu Sublime 配置

    p { margin-bottom: 0.25cm; line-height: 120% } a:link { } 2018.4.14 Ubuntu Sublime 配置 承 Ubuntu Apach ...

  4. [LeetCode] String Compression 字符串压缩

    Given an array of characters, compress it in-place. The length after compression must always be smal ...

  5. JavaScript的作用;JS常见的三种对话框;==和===的区别;函数内部参数数组arguments在函数内部打印实参;JS的误区:没有块级作用域

    JS:客户端(浏览器)脚本语言 弱类型 基于原型 事件驱动 不需要编译(直接运行)   JS的作用:表单验证,减轻服务端的压力 添加页面动画效果  动态更改页面内容  Ajax网络请求 (一)常见的对 ...

  6. [NOI2009]变换序列

    Description Input Output Sample Input 5 1 1 2 2 1 Sample Output 1 2 4 0 3 HINT 30%的数据中N≤50: 60%的数据中N ...

  7. 【HDU 1576】 A/B

    Problem Description 要求(A/B)%9973,但由于A很大,我们只给出n(n=A%9973)(我们给定的A必能被B整除,且gcd(B,9973) = 1).   Input 数据的 ...

  8. ●POJ 1509 Glass Beads

    题链: http://poj.org/problem?id=1509 题解: 给出一个字符串,有一个操作:把首字符放到末尾,形成新的串.求任意次操作后,字典序最小的串的首字母在原串中的位置.(这就是最 ...

  9. UESTC 618 无平方因子数 ( 莫比乌斯)

    UESTC 618 题意:求1到n中无平方因子数的个数 Sample Input 3  1  10  30 Sample Output 1  7  19 思路:与前面的BZOJ 2440相似 #inc ...

  10. springmvc上传文件方法及注意事项

    本文基于注解的配置,敬请留意  基于注解整合 一.springmvc为我们提供两种上传方式配置: org.springframework.web.multipart.commons.CommonsMu ...