【c语言】2维数组求平均值,指针出问题了

问题描述

【c语言】2维数组求平均值,指针出问题了

double average(double (*p)[],double *q,int n,int m)
{
int i,j;

double NU,AE;//每列总和与每行总和
for(i=0;i<n;i++)
{
    for(NU=0,j=0;j<m;j++)
    {
        NU+=(*p+i)[j];//每列的和
    }
    q[i]=NU/m;//每行的平均值
    AE+=NU;//每行的和
}
return AE/(n*m);//总平均值

}


第一行的平均值没错!第2行开始的平均值有错!
猜测NU+=(*p+i)[j];这出错了!试过NU+=p[i][j];无法编译!
也是个改参数!把(*p)[]改成**p,把NU+=(*p)[j]改成NU+=(*(*p+i)+j);
无法编译!

需求是求2次平均值!
1个是行的平均值,
1个是总平均值!

解决方案

for (NU = 0, j = 0; j < m; j++) {
NU += (*p + n*i)[j]; //每列的和
}

    指针增加的不对

解决方案二:

如果还是不对,可能是你的AE没有初始化为0,局部变量不初始化会是随机值。

解决方案三:

二维数组直接用下面的方式就行了:
for (NU = 0, j = 0; j < m; j++)
{
NU += p[i][j];
}

解决方案四:

首先,average的第一个参数的维数不能为空。
其次,访问数组指针的方式不对。
下面附上修改后的代码及测试案例.
在代码中已经标注好了备注,请参考.

 #include<stdio.h>
//这个average函数中,第一个参数的维数不能为空。
double average(double(*p)[3], double *q, int n, int m)
{
    //m代表列数,n代表行数。q指向一个数组,共有n个元素。
    int i, j;
    double NU = 0;//每行的总和 ,需要在这里进行初始化
    double AE = 0;//所有数据的总和
    for (i = 0; i < n; i++)
    {
        for (NU = 0, j = 0; j < m; j++)
        {
            NU += p[i][j];//每行的和 //这里不是(*p + i)[j],你可以写p[i][j]或者*(p+i)[j]
        }
        q[i] = NU / m;//每行的平均值
        AE += NU;//AE 是总和
    }
    return AE / (n*m);//总平均值
}
void main()
{
    double buf[2][3] = { { 1.2, 2.3, 3.4 }, { 4.5, 5.6, 6.7 } };
    double p[2] = { 0 };
    double aver=average(buf, p, 2, 3);
    for (int i = 0; i < 2; i++)
        printf("%gt", p[i]);
    putchar(10);
    printf("%gn", aver);
}

时间: 2024-12-30 17:51:09

【c语言】2维数组求平均值,指针出问题了的相关文章

二维数组与指针-C语言二维数组中的*(p+1)的确切含义

问题描述 C语言二维数组中的*(p+1)的确切含义 各位大师们,烦请指教一二吧.如果是在一维数组中,*(p+1)表示p+1这个地址空间或空间中的值,那么在二维数组中,p+1是指向a[1]*(p+1)是a1这个地址中的值啊?可是为什么会是地址呢? 解决方案 二维数组其实是一个小戏法,本质上还是一维数组--二维下标连续构成的数组又连续构成第一维下标.你可以像遍历一维数组那样遍历它 解决方案二: 其实a[2][3]的调用可以看成是两个调用,首先是对a进行[2]操作,然后再对a[2]的返回值进行[3]操

数组 指针-c语言二维数组的指针问题

问题描述 c语言二维数组的指针问题 在WinTC下运行如下代码 #include void main() { char a1[][5]={"ab","cd","ef","ghi","sfs"}; printf("%sn",*(a1+3)); //语句1 printf("%cn",**(a1+3)); //语句2 } 运行结果为: ghi g 但如果将上述语句1中的%s

C语言二维数组指针问题

问题描述 C语言二维数组指针问题 如下两个代码,第一个代码会停止运行,而第二个能得出正确结果...这两个代码的不同之处不应该是等价的吗?为什么会造成这种完全相反的结果? #include<stdio.h> void main() { void ave(float *p,int m); float a[3][4]={{65,66,67,68},{78,79,80,71},{54,78,65,54}}; ave(*a,12); } void ave(float *p,int m) { float

C语言中二维数组指针的简要说明_C 语言

C语言中,指针是一个复杂但又灵活多变的知识点,我们知道,在一维数组中,对于一个数组a[],*a,a,&a,都表示a的首地址,但如果与二维数组混合使用,就显得更为复杂了.例如对于一个二维数组 a[2][4]={{1,2.3},{4,5,6}} a+i,&a[i],*(a+i),a[i], 这四个表达式到底表示什么呢? 先告诉答案吧,其实这几个表达式都是指向同一个地址的,也许你会很诧异,也会很疑惑,怎么会是这样呢!!事实证明就是这样的, C语言中,指针是一个复杂但又灵活多变的知识点,我们知道,

c语言-怎么随机给二维数组赋值,指针表示

问题描述 怎么随机给二维数组赋值,指针表示 #define M 25 #define N 25 int array[M][N]; int i, j; void Rand(int *p, int n) { p = &array[0][0]; for(i = 0;i<n;i++ { *(p + i) = rand()%100; } } 这是一维指针,要求是二维,怎么破 解决方案 #include #include //输出数组中的数字 void Output(int *a, int len);

c语言-C++ CString类型二维数组 求长度

问题描述 C++ CString类型二维数组 求长度 ```CString bb[100][100] = [[a,b,c],[d,e,f],[g,h,i]] 怎么获取里面一维数组长度 3 解决方案 整个遍历一遍呗!否则还有什么好方法吗? 解决方案二: 只能遍历二维数组 然后取对应的长度 解决方案三: 建议使用动态数组,这样浪费栈区内存 解决方案四: sizeof(bb[0]) 解决方案五: 只能遍历了吧--可以写个遍历求长度的函数,调用就行,不过这样太麻烦 推荐使用动态数组,然后用sizeof应

c语言-C语言二维数组下标越界--却能给越界的下标赋值 和输出

问题描述 C语言二维数组下标越界--却能给越界的下标赋值 和输出 编译器:dev-c++ int iArray[3][4]; iArray[3][4]=1000; printf("%d",iArray[3][4]); 改变 iArray[3][4]的值为1000 输出的结果仍然为1000 请问这个是什么原因呢? 我是直接给越界的下标进行了赋值 以前以为只要是下标越界了 输出的都是无意义的数字 其实那是因为没有给越界的下标赋值 对吗 越界的下标为什么还能正常使用呀 解决方案 使用越界的数

c二维数组名与指针的指针之间的关系

问题描述 c二维数组名与指针的指针之间的关系 int arr[3][4]; 书上说arr是指针的指针. 但是有点问题,为什么arr和arr[0]的值是一样的. 如果它是指针的指针的话,那么arr应该在一个内存空间1中存着arr[0]的地址,这个内存空间也有自己的地址. 但是这个内存空间的地址却与内存空间中存着的地址是相同的... 解决方案 arr的值本身是二维数组的首地址,它存储的内容也是数组的首地址 printf("%p %p ", arr, *arr);// 这2个值一样,它存储的

编程c语言-C语言二维数组问题 求解

问题描述 C语言二维数组问题 求解 解决方案 bool foo() { int a[100][100]; int i,j; for(i=0;i<n;i++) { for(j=0;j<n;j++) { scanf("%d",a[i][j]); } } int sum = 0; int sum1 = 0; for (i = 0; i < n; i++) sum += a[i][0]; for (j = 0; j < n; j++) { sum1 = 0; for (