• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆 - 16, 文章 - 1, 評論 - 4, 引用 - 0
            數據加載中……

            C++中如何動態分配二維數組

            一、問題的提出

            //////////////////////////////////////////////////////

            #include <iostream.h>

            const int M=200;

            void main()
            {
            double a[M][M], b[M][M];
            double aa=0, bb=0;

            for(int i=0; i<M; i++)
            for(int j=0; j<M; j++)
            {
            a[i][j]=1.0;
            b[i][j]=1.0;

            aa+=a[i][j];
            bb+=b[i][j];
            }

            cout<<"aa="<<aa<<",  bb="<<bb<<endl;
            }

            ////////////////////////////////////////////////////////

            M=200,運行很正常,可以輸出結果。當M=300時就會出現運行錯誤。

            是不是C++中對數組大小有限制,怎么申請大數組呢?

            高人指點:
            你這種方法建的數組好象是存在STACK里, 大小有限制.
            2維數組在C/C++里不是很好用.建議用一維數組代替, 可以用 NEW 建指針數組, 這樣可以用大數組.
            其實最好用VECTOR, 做動態時很方便, 而且從2維到3維也更自然一些

             

            二、問題的解決

            A.用一維數組代替,應用new、delete命令。

            //////////////////////////////////////////////////////

            #include <iostream.h>

            const int M=500;

            void main()
            {
            double *a, *b;
            double aa=0, bb=0;

            a=new double[M*M];
            b=new double[M*M];

            for(int i=0; i<M; i++)
            for(int j=0; j<M; j++)
            {
            a[i+j*M]=1.0;
            b[i+j*M]=1.0;

            aa+=a[i+j*M];
            bb+=b[i+j*M];
            }

            cout<<"aa="<<aa<<",  bb="<<bb<<endl;

            delete []a;
            delete []b;
            }

            ///////////////////////////////////////////////////////

            OK,用NEW建指針數組,運行通過,M=1000都沒問題, :)

            B.用vector命令。

            ////////////////////////////////////////////////////////

            #include <iostream.h>
            #include <vector>

            using std::vector;

            const int M=1000;

            void main()
            {
            vector <double> a(M*M);
            vector <double> b(M*M);

            double aa=0, bb=0;

            for(int i=0; i<M; i++)
            for(int j=0; j<M; j++)
            {
            a[i+j*M]=1.0;
            b[i+j*M]=1.0;

            aa+=a[i+j*M];
            bb+=b[i+j*M];
            }

            cout<<"aa="<<aa<<",  bb="<<bb<<endl;
            }

            ////////////////////////////////////////////////////////////////

            OK,好像也可以,不錯不錯。

            C.網上找到個比較好的。


            http://nothingnowhere.blogchina.com/4539351.html

            c++中如何動態分配二維數組
            關鍵詞: 二維數組                                          

            #include<iostream.h>

            void main()
            {
            int **p;
            int N,M,s=0;
            cin>>N>>M;

            p = new int*[N];
            for(int i=0;i<N;i++) { p[i] = new int[M];  }

            for(int j=0;j<M;j++)
             for(int k=0;k<N;k++)
             {p[k][j]=s++; cout<<p[k][j]<<endl;}
            }
            /////////////////////////////////////////////////

            這個方法確實不錯,用起來更方便。

            posted on 2007-07-17 13:24 東東會會 閱讀(4309) 評論(2)  編輯 收藏 引用 所屬分類: C++ 基礎

            評論

            # re: C++中如何動態分配二維數組  回復  更多評論   

            最后一個怎么沒有釋放內存?
            2008-06-18 22:03 | lm

            # re: C++中如何動態分配二維數組  回復  更多評論   

            @lm

            嗯 會造成內存泄漏~~
            2008-10-19 21:06 | shan
            精品久久久久久久无码| 99久久www免费人成精品| 久久精品国产影库免费看| 午夜精品久久影院蜜桃| 国产精品久久久久jk制服| 久久精品人人做人人爽电影| 94久久国产乱子伦精品免费| 99久久99久久精品免费看蜜桃| 日本久久久久久久久久| 91精品国产高清久久久久久91| 天天躁日日躁狠狠久久| 国产aⅴ激情无码久久| 国产欧美久久久精品影院| 久久久久女教师免费一区| 精品久久久久久无码人妻蜜桃| 99久久精品国产毛片| 国产精品无码久久久久 | 久久激情五月丁香伊人| 久久久久无码精品| 日日狠狠久久偷偷色综合96蜜桃| 色诱久久av| 久久亚洲私人国产精品vA| 一本大道久久a久久精品综合| 国产精品久久久久久久久鸭| 久久www免费人成看国产片| 久久中文精品无码中文字幕| 色欲av伊人久久大香线蕉影院| 国产精品99久久99久久久| 欧美久久久久久午夜精品| 久久天天躁狠狠躁夜夜躁2014| 色婷婷综合久久久久中文| 久久精品无码一区二区app| 思思久久99热只有频精品66| 久久精品亚洲一区二区三区浴池| 国产精品青草久久久久福利99| 天天爽天天狠久久久综合麻豆| 日韩一区二区三区视频久久| 老司机国内精品久久久久| 亚洲午夜久久久久妓女影院| 久久伊人五月天论坛| 久久强奷乱码老熟女网站|