把一个上三角矩阵变换成一个满矩阵
Transform an upper triangular matrix into a full matrix C++
如何将上三角矩阵转换为满矩阵的代码?这个矩阵是一个向量,而不是一个二维数组…
那么数组
[ 1 2 3 4
0 5 6 7
0 0 8 9
0 0 0 10 ]
将变成像
这样的数组:[ 1 2 3 4
2 5 6 7
3 6 8 9
4 7 9 10 ]
你能提供一些想法吗,我在考虑应用一种模块之类的东西…
有一个限制,我不使用二维数组我用的是矢量,所以是一维数组
首先,您必须了解反射矩阵的基本性质。对于任意i
, j
,以下断言为真:
m[i][j] ≡ m[j][i]
需要一些算法来实现。我可以建议:
for(int i = 0; i < HEIGHT; ++i)
for(int j = 0; j < i; ++j)
m[i][j] = m[j][i];
注意第二个循环的条件。通过确保j
总是小于i
,我们将活动限制在左下角的三角形。
接下来,您必须了解如何在一维数组中实现二维矩阵。看来你已经建立了身份:
m[i][j] ≡ v[i*WIDTH+j]
替换,我们有:
for(int i = 0; i < HEIGHT; ++i)
for(int j = 0; j < i; ++j)
v[i*WIDTH+j] = v[j*WIDTH+i];
相关文章:
- 如何创建一个CMake变量,除非显式重写,否则使用默认值
- 删除一个线程上有数百万个字符串的大型哈希映射会影响另一个线程的性能
- 为什么两个不同的未命名名称空间可以共存于一个cpp文件中
- 运行同一解决方案的另一个项目的项目
- 挂起和取消挂起一个文件DLL
- 用C++中的一个变量定义一个常量
- 函数向量_指针有不同的原型,我可以构建一个吗
- 在c++中用vector填充一个简单的动态数组
- 如何在选项卡视图Qt中设置一个新项目,并保存以前的项目
- 预处理器:插入结构名称中的前一个行号
- 我在c++代码中生成了一个运行时#3异常
- 我想将一个对T类型的非常量左值引用绑定到一个T类型的临时值
- 从链接列表c++中删除一个项目
- 告诉一个 const char 数组,除了编译时 C 样式的字符串外,它不以 '