标题:各位大哥如何创建一个超大的二维数组,并将数据储存进去,转置再读取出来?
取消只看楼主
校草
Rank: 1
等 级:新手上路
帖 子:50
专家分:7
注 册:2017-3-15
结帖率:75%
已结贴  问题点数:10 回复次数:2 
各位大哥如何创建一个超大的二维数组,并将数据储存进去,转置再读取出来?
没用过直接定义数组以外的其他定义方式,之前大一点的用Static可以解决,现在这个数组实在太大了。。在网上照猫画虎的,也不知道怎么修改,还请各位指教
贴出部分代码,为了测试改成了一个5*3的数组,原来是一个33600*27375的数组,
printf("%3.2f\n", arr[i][j]),打印的全是0.00
程序代码:
//======================================================
//将oringin文件进行转置,最后输出的a矩阵
//
//======================================================
//基本数据
const int HANG =5;//33600行(总网格数)!!修改
const int LIE = 3;// 27375列(总天数,也就是数据量)!!修改
//=====================================================
//基本数据!!!!!修改


const int yrolls = 3;//列数
const int xrolls = 5; //行数


int main(){
//======================================================
//文件操作
FILE* out, *in;
in = fopen("F:\\2017C\\5X3.asc", "r");//输!入!!!修改
out = fopen("F:\\2017C\\3x5.asc", "w");//输出!!修改

//创建大型二维arr矩阵
const int M = HANG, N = LIE;//M行N列(每一行有27375个数据)

int**  arr = (int **)malloc(sizeof(int *)*M);

for (int i = 0; i<M; i++)

    arr[i] = (int *)malloc(sizeof(int)* N);

//读入数据
while (!feof(in))
{

    for (int i = 0; i < HANG; i++){   //i<行数 210行*160列
        for (int j = 0; j < LIE; j++){   //j<列数 75年*365天
            fscanf(in, "%f", &arr[i][j]);
            printf("%3.2f\n", arr[i][j]);
        }
    }
}
for (int i = 0; i<M; i++)

    free(arr[i]);

free(arr);



[此贴子已经被作者于2017-12-15 14:58编辑过]

搜索更多相关主题的帖子: 数据 数组 修改 int const 
2017-12-15 14:48
校草
Rank: 1
等 级:新手上路
帖 子:50
专家分:7
注 册:2017-3-15
得分:0 
回复 2楼 rjsp
是不是应该改成:
float**  arr = (int **)malloc(sizeof(int *)*M);

for (int i = 0; i<M; i++)

    arr[i] = (int *)malloc(sizeof(int)* N);



另外还想问一下如果要创建一个三维数组,元素是float型的,arr[19710][210][160],大概有多大,
如何创建呢?
2017-12-15 16:33
校草
Rank: 1
等 级:新手上路
帖 子:50
专家分:7
注 册:2017-3-15
得分:0 
回复 4楼 GBH1
抱歉,因为任务比较急,慢慢摸索没有时间了,还请大哥指教!
三维arr[A][B][C]的float元素是不是如下呢:

程序代码:
float*** CreateGrid(int A,int B,int C)
{
    int*** arr = NULL;

    tt = (int***)malloc(sizeof(int)*A);
    for(int i=0;i<A;i++)
    {
        arr[i] = (int**)malloc(sizeof(int)*B);;
        for (int k=0;k<B;k++)
        {
            arr[i][k] = (int*)malloc(sizeof(int)*C);
        }
    }
    return arr;
}
void FreeGrid(int*** arr,int A,int B,int C)
{
    if(arr != NULL)
    {
        for(int i=0;i<A;i++)
        {
            for (int j=0;j<B;j++)
                                                    {
                free((arr[i][j]));
            }
            free(arr[i]);
        }
        free(arr);
        arr = NULL;
    }
}


遍历是不是:
    for (int i = 0; i < A; i++) {
        for (int j = 0; j < B ; j++) {
            for (int k = 0; k < C; k++){
                fscanf(file,%f,&arr[i][j][k])
               }
        }
    }

                 
2017-12-16 10:44



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-483398-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.475149 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved