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

            劉加加在成長(C++語言學習中)

            學習、工作、生活,這是三個問題。

              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              38 隨筆 :: 0 文章 :: 24 評論 :: 0 Trackbacks
            #include<stdio.h>
            #define ROWS 3
            #define COLS 4
            void sum_rows(int arr[][COLS],int rows);
            int main(void)
            {
                
            int junk[ROWS][COLS]={{1,2,3,4},{5,6,7,8},{9,10,11,12}};
                
                sum_rows(junk,ROWS);
            //求出每行的數(shù)值總和。 
                
                getchar();
                
            return 0;

            void sum_rows(int arr[][COLS],int rows)
            {
                
            int r,c,tot;
                
            for(r=0;r<rows;r++)
                {
                    tot
            =0;
                    
            for(c=0;c<COLS;c++)
                    {
                        tot
            +=arr[r][c];
                    }
                    printf(
            "row%d,sum=%d\n",r,tot);
                }
            }

            我們都知道上面的代碼可以順利執(zhí)行, sum_rows()的形參是 int arr[][COLS],沒有指定數(shù)組的第一維大小。但是設想一下,如果不指定第二維的大小,結果會怎樣呢?
            我寫了以下例子:
            #include <stdio.h> 
            int sum2d(int arr[][],int row,int col); 
            int main(void

                
            int arr[3][4]={{1,2,3,5},{3,4,4,5},{2,3,4,5}}; 
                sum2d(arr,3
            ,4); 
                 
                getchar(); 
                
            return 0;  

            int sum2d(int arr[][],int row,int col) 

                
            for(int i=0;i <row;i++
                { 
                    
            for(int j=0;j <col;j++
                    { 
                        printf(
            "%d",arr[i][j]);  invalid use of array with unspecified bounds         
                    } 
                } 
                
            return 0

            運行后發(fā)現(xiàn),程序報錯了,這是為什么呢?百思不得其解,后來請教了CSDN上老大們。終于稍微弄明白了點兒。我想具體應該從兩方面證明為什么上面的程序不可行。
            (1)從二維數(shù)組的存儲方式上:二維數(shù)組在內存上是一行一行連續(xù)的存儲的。如下圖:
            arr[3][4]
            arr[0][0] arr[0][1] arr[0][2] arr[0][3] arr[1][0] arr[1][1] arr[1][2] arr[1][3] ...

            因為arr是這個數(shù)組的首地址,我們可以知道arr[0][0]的地址。只要我們知道arr[][4]中數(shù)組第二維的大小‘4’,我們就可以找到任意行和列的地址。address=arr+(rows-1)*4+cols。但是如果不知道第二維的大小,那么條件就不夠了。打一個比方,將若干個學生分成每組11人,并讓他們站成一排,這時我們可以定位出第幾組的第幾個學生。但如果不知道每組11個人,那么我們顯然就無法定位了。

            (2)從指針的角度上看(這種思路我還是有點迷糊):大家可以參看這個帖子:http://topic.csdn.net/u/20080520/09/2122e210-5cf5-4b75-b31f-c2523b00cf53.html?575319732

            恩,現(xiàn)在是越學越迷惑了。呵呵。
            posted on 2008-05-20 22:31 劉加加 閱讀(888) 評論(0)  編輯 收藏 引用 所屬分類: 學習C語言
            国内精品久久国产| 亚洲欧美一级久久精品| 国产精品久久午夜夜伦鲁鲁| av国内精品久久久久影院| 日韩精品久久久久久| 日日狠狠久久偷偷色综合0| 久久丫精品国产亚洲av不卡| 国产激情久久久久影院老熟女免费| 精品久久久久久亚洲| 无码人妻精品一区二区三区久久久 | 成人亚洲欧美久久久久| 无码任你躁久久久久久老妇| 久久SE精品一区二区| 99久久无码一区人妻| 无码人妻少妇久久中文字幕蜜桃| 欧美伊香蕉久久综合类网站| 久久婷婷色香五月综合激情| 久久综合噜噜激激的五月天| 亚洲AV伊人久久青青草原| 久久91亚洲人成电影网站| 伊人久久大香线蕉av不卡| 少妇久久久久久被弄到高潮 | 东京热TOKYO综合久久精品| 狠狠久久综合| 国产精品美女久久久久网| 久久香蕉超碰97国产精品| 久久这里只有精品首页| 99久久精品九九亚洲精品| 成人综合伊人五月婷久久| 久久亚洲精品国产精品| 久久丫精品国产亚洲av| 久久夜色精品国产欧美乱| 久久久久久国产精品无码超碰| 亚洲午夜久久久久久久久久| 久久久久久久综合综合狠狠| 久久久综合香蕉尹人综合网| 久久久精品一区二区三区| 国产精品内射久久久久欢欢| 久久国产乱子伦精品免费强| 国产成人无码精品久久久久免费| 9191精品国产免费久久|