二維數組做爲函數參數的幾種方法

給定程序中,函數fun的功能是:有N×N矩陣,以主對角線爲對稱線,對稱元素相加並將結果存放在左下三角元素中,右上三角元素置爲0。
**例如,若N=5,有下列矩陣: 1 2 3 4 5 計算結果爲:1 0 0 0 0*/

#include <stdio.h> #define N 5 void fun1(int a[N][N]) { int i,j; for (i=0;i<N;i++) { for (j=0;j<N;j++) { if (i>j) { a[i][j]+=a[j][i]; a[j][i]=0; } } } }
void fun2(int **a,int m,int n) { int i,j; for (i=0;i<m;i++) { for (j=0;j<n;j++) { if (i>j) { *((int *)a+i*m+j)+=*((int *)a+j*m+i); *((int *)a+j*m+i)=0; } } } } void fun3(int *a,int m,int n) //數組按行存儲,能夠看作一位數組,存取位置要本身控制
{
int i,j; for (i=0;i<m;i++) { for (j=0;j<n;j++) { if (i>j) { *(a+i*m+j)+=*(a+j*m+i); *(a+j*m+i)=0; } } } } int main() { int b[5][5]={{1,2,3,4,5},{2,3,4,5,6},{3,4,5,6,7},{4,5,6,7,8},{5,6,7,8,9}}; //fun1(b); //fun2((int **)b,5,5); fun3(*b,5,5); for (int i=0;i<5;i++) { for (int j=0;j<5;j++) { printf("%3d ",b[i][j]); } printf("\n"); } return 0; }

//數組按行存儲數組

若是二維數組知道一維長度,只有一個維數長度爲變量,能夠用數組指針。函數

數組名的指針,即數組首元素地址的指針。便是指向數組的指針。
例:int (*p)[10]; p即爲指向數組的指針,又稱數組指針。
int a[4][5];int (*p)[5]=a;
void fun4(int (*a)[5],int m)
{
    int i,j;
    for (i=0;i<m;i++)
    {
        for (j=0;j<5;j++)
        {
            if (i>j)
            {
                *(*(a+i)+j)+=*(a[j]+i);
                *(a[j]+i)=0;

            }
        }
    }
    
}

int (*p1)[5];
    int **p2;
我以爲上面兩個類似。只有一些小小的不一樣..
p1指向一維數組的指針

p2是一個指向指針的指針,沒有本身的內存區域。能夠隨意指向任意一塊內存區域.spa

相關文章
相關標籤/搜索