• <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>

            千張筆記

            Email:rain_qian830@163.com
            posts - 28, comments - 42, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            【轉】實現兩個N*N矩陣的乘法

            Posted on 2010-05-23 18:09 千張 閱讀(2422) 評論(3)  編輯 收藏 引用 所屬分類: 程序員筆試寶典

            題目:實現兩個N*N矩陣的乘法,矩陣由一維數組表示。

            答案:

            #include <iostream>
            using namespace std;

            #define  SIZE 2

            int* multi(int* array_a,int* array_b,int N)
            {
                
            int* array_c = (int*)malloc(N*N);
                
            int temp;
                
            for (int i = 0; i < N; ++ i)
                    
            for(int j = 0; j < N; ++ j)
                
            {
                    temp 
            = i * N + j;
                    
            *(array_c + temp) = 0;
                    
            for (int k = 0; k < N; ++ k)
                    
            {
                        
            *(array_c + temp) += array_a[i * N + k] * array_b[k * N + j];
                    }

                    cout 
            << *(array_c + temp) << " ";
                    
                }

                
            return array_c;
            }


            int main()
            {
                
            int array_a[SIZE * SIZE] = {1,2,1,2};
                
            int array_b[SIZE * SIZE] = {2,1,2,1};
                
            int* array_c = multi(array_a,array_b,SIZE);
                free(array_c);
                
            return 0;

            }




            注意:malloc或new分配內存后,要用free或delete釋放內存,要不然可能有“_CrtIsValidHeapPointer異常”,也會有內存泄露。

            From:http://hi.baidu.com/feigudian/blog/item/ac608c013c81d0d5277fb5ee.html

            Feedback

            # re: 【轉】實現兩個N*N矩陣的乘法  回復  更多評論   

            2010-08-07 17:25 by 游客
            這個程序運行時還是有一個bug,應該是malloc和free的問題

            # re: 【轉】實現兩個N*N矩陣的乘法  回復  更多評論   

            2010-08-07 17:28 by 游客
            我認為,在multi和main中的array_c不是一個

            # re: 【轉】實現兩個N*N矩陣的乘法  回復  更多評論   

            2011-10-03 20:14 by fuhuaqing
            malloc大小弄錯了,應該是arr_c = (int *)malloc(N*N*sizeof(int));
            分配大小不夠。
            久久97久久97精品免视看秋霞| 久久精品无码免费不卡| 亚洲午夜精品久久久久久app| 久久久久国产精品嫩草影院| 99精品久久久久久久婷婷| 久久国产精品无码一区二区三区| 久久精品男人影院| 亚洲人成伊人成综合网久久久| 国产精品美女久久久久| 色综合久久久久综合99| 精品久久久久久综合日本| 日本精品一区二区久久久 | 国产精品久久免费| 久久精品国产男包| 久久大香香蕉国产| 欧美精品九九99久久在观看| 色综合色天天久久婷婷基地| 无码AV中文字幕久久专区| 久久久久免费视频| 久久精品一区二区国产| 囯产精品久久久久久久久蜜桃| 99久久综合狠狠综合久久| 亚洲AV乱码久久精品蜜桃| 日韩va亚洲va欧美va久久| 久久久久久国产精品免费免费| 国产一级持黄大片99久久| 国内精品伊人久久久久AV影院| 97久久国产露脸精品国产| 亚洲精品午夜国产va久久| 色综合久久天天综线观看| 久久夜色精品国产www| 三级韩国一区久久二区综合| 国内精品久久久久久不卡影院| 国产成人精品久久二区二区| 久久久一本精品99久久精品88| 人妻无码久久一区二区三区免费| 久久永久免费人妻精品下载| 一本色道久久88精品综合| 熟妇人妻久久中文字幕| 久久亚洲精品中文字幕| 久久免费高清视频|