• <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, 評(píng)論 - 4, 引用 - 0
            數(shù)據(jù)加載中……

            C++中如何動(dòng)態(tài)分配二維數(shù)組

            一、問題的提出

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

            #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,運(yùn)行很正常,可以輸出結(jié)果。當(dāng)M=300時(shí)就會(huì)出現(xiàn)運(yùn)行錯(cuò)誤。

            是不是C++中對(duì)數(shù)組大小有限制,怎么申請(qǐng)大數(shù)組呢?

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

             

            二、問題的解決

            A.用一維數(shù)組代替,應(yīng)用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建指針數(shù)組,運(yùn)行通過,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,好像也可以,不錯(cuò)不錯(cuò)。

            C.網(wǎng)上找到個(gè)比較好的。


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

            c++中如何動(dòng)態(tài)分配二維數(shù)組
            關(guān)鍵詞: 二維數(shù)組                                          

            #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;}
            }
            /////////////////////////////////////////////////

            這個(gè)方法確實(shí)不錯(cuò),用起來更方便。

            posted on 2007-07-17 13:24 東東會(huì)會(huì) 閱讀(4322) 評(píng)論(2)  編輯 收藏 引用 所屬分類: C++ 基礎(chǔ)

            評(píng)論

            # re: C++中如何動(dòng)態(tài)分配二維數(shù)組  回復(fù)  更多評(píng)論   

            最后一個(gè)怎么沒有釋放內(nèi)存?
            2008-06-18 22:03 | lm

            # re: C++中如何動(dòng)態(tài)分配二維數(shù)組  回復(fù)  更多評(píng)論   

            @lm

            嗯 會(huì)造成內(nèi)存泄漏~~
            2008-10-19 21:06 | shan
            久久久这里有精品中文字幕| 久久国产免费观看精品3| 狠狠色丁香久久婷婷综合五月 | 少妇无套内谢久久久久| 亚洲日本va中文字幕久久| 99久久人妻无码精品系列蜜桃| 国产伊人久久| 久久久久无码精品国产不卡| 日本久久中文字幕| 国产精品久久久久jk制服| 久久亚洲高清综合| 99精品久久精品一区二区| 一级做a爰片久久毛片毛片| …久久精品99久久香蕉国产| 久久人人爽人人人人片av| 久久国产乱子伦精品免费午夜| 久久人人爽人人爽人人片AV不| 亚洲国产成人精品久久久国产成人一区二区三区综 | 人人狠狠综合久久亚洲| 久久国产乱子伦精品免费强| 精品无码久久久久国产动漫3d| 九九热久久免费视频| 91视频国产91久久久| 亚洲香蕉网久久综合影视| 色老头网站久久网| 久久精品这里只有精99品| 精品国产乱码久久久久久浪潮| 久久久青草青青亚洲国产免观| 久久w5ww成w人免费| 久久久久久夜精品精品免费啦| 久久精品国产乱子伦| 久久无码专区国产精品发布| 伊人伊成久久人综合网777| 久久久人妻精品无码一区| 精品无码久久久久久久动漫| 久久精品国产亚洲av瑜伽| 久久久久国产精品麻豆AR影院| 久久国产精品无码网站| 欧美粉嫩小泬久久久久久久| 亚洲国产天堂久久综合| 国产69精品久久久久9999APGF|