要在C++中定义一个很大的矩阵,如何定义

如1000*2000

有以下几种方法在C++中定义大矩阵:

    数组定义

    直接使用数组进行定义,这种情况一般会使用静态地址,数组访问下标也比较方便。但是在数量上不能太大。因为这类数组一般会分配到系统的栈空间,而对Windows来说,这个空间大约是2M左右(也有的资料说是1M),总之大小是一常量

    定义和使用数组的方法如下:

int a[500][200];//定义一个二维数组

int k=a[3][5];//将一个数组元素赋值给k

 2.申请指针空间

    通过指针申请一个较大的空间,再使用算法计算元素所在的位置。

    由于申请的空间在堆上,而堆的空间容量要远大于栈空间。所以它在容量上会更大,但是在使用时,需要使用代码计算元素的地址,复杂度稍有提高。

    定义和使用方法如下:

int * a=new int[1000*2000];//定义指针a,且向系统申请1000*2000个数据元素需要的空间

int k=*(a+20);//将a[20]赋值给k

温馨提示:答案为网友推荐,仅供参考
第1个回答  2015-04-15
定义成全局变量 也就是写在 main函数的外面追问

可以发一下程序示例不

追答#include<stdio.h>
int a[1000][2000];
int main() {
    printf("%d",sizeof(a));
}

嗯  您看看这样的示例可以吗    望采纳

本回答被提问者采纳
第2个回答  2015-04-15

c++用应对这个数学向量矩阵运算有一个 valarray,你可以看下可能是你需要的,你可以了解下。

#include <valarray>
using std::valarray;

第3个回答  2015-04-15
根据用途可以定义成二维数组,也可定义成链表。
第4个回答  2015-04-16
int map[1000][2000]

相似回答