A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© lixp 中级黑马   /  2015-10-30 18:18  /  728 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

#include<stdio.h>
int sumArray(int arr[][3],int row, int colom);
int sumArrayPointer(int (*p)[3],int row,int colom);
int main(int argc,char * argv[]){
        //定义一个二维数组
        int arr[][3]={1,2,3,4,5,6,7,8,9};//二维数组前面一个应该可以不写吧
        int size=sizeof(arr)/sizeof(arr[0][0]);//在这儿要注意,求出来之后要计算二维数组的行和列
        int row=size/3;
        int colom=3;
        int sum=sumArray(arr,row,colom);
        int sum2=sumArrayPointer(arr,row,colom);
        printf("最终结果是:sum(arr)=%d\n",sum);
        printf("最终结果是:sum2(arr)=%d\n",sum2);
return 0;
}
//数组方式求和(一定要注意,数组的列必须要有,可以没有行的大小)
int sumArray(int arr[][3],int row,int colom){
        int i,j;
        int sum=0;
        for(i=0;i<row;i++){
                for(j=0;j<colom;j++){
                        sum+=arr[i][j];
                }
        }
        return sum;
}
//以指针的形式求和
int sumArrayPointer(int (*p)[3],int row,int colom){
        int i,j;
        int sum=0;
        for(i=0;i<row;i++){
                for(j=0;j<colom;j++){
                        sum+=*(*(p+i)+j);//这一步很重要,不能写错 *(p+i)表示循环访问每一行,*(p+i)+j,才表示访问每一行每一列
                }
        }
        return sum;
}

1 个回复

倒序浏览
顶顶顶顶顶顶顶顶顶顶
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马