为矩阵(n*1)分配内存
allocate a memory for a matrix (n*1)
我想创建一个n*1的矩阵(一个单列矩阵)。n
可以是任意整数)
我认为应该是这样的:
int mat[][1];
cin >> n;
*mat = new int[n]*;
感谢任何帮助!
如果您声明您的矩阵为:
int mat[][1];
这意味着你没有做动态内存分配。
你应该这样做:
int **mat = new int*[n]; //n is number of rows
for (int i = 0; i < n ;++i)
{
mat[i] = new int[1];
}
无论如何,您应该更喜欢使用std::vector
而不是使用动态分配的数组,特别是当您只有1列时。
int * * mat = new int * [ n ];
相关文章:
- 在c++中为我自己的基于指针的数组分配内存的正确方法
- 给定一个指向堆分配内存的指针,智能指针实现如何为其找到合适的释放函数?
- 如果 const 不分配内存,为什么我可以获取 const 的地址?
- 在函数中分配内存时出现问题
- 如何为 std::vector 分配内存,然后稍后为某些元素调用构造函数?
- constexpr new 如何分配内存?
- 在构造函数中分配内存失败是如何冒泡的
- LLVM 传递以在特定地址分配内存
- CudaMalloc 在分配内存时失败
- 为什么它在不分配内存的情况下工作正常
- 为什么在正确解除分配内存时出现内存泄漏?
- 如何通过 malloc 为队列数组分配内存?
- vector是否为std::移动的对象连续分配内存
- 删除类成员的动态分配内存的最佳方法是什么
- 唯一指针是否在堆或堆栈上分配内存?
- 如果不分配内存,我如何能够为变量创建和分配值?
- std::initializer_list 堆是否分配内存?
- 如何按顺序或在指定的地址分配内存?
- 是否可以使用 malloc 为类对象分配内存?
- 迭代器是否分配内存(如指针)?