C++中给函数传参二维数组

有 4 种方式

void f1(int a[N][M]);
void f2(int a[][N]);
void f3(int (*a)[N]);
void f4(int *a);

实例如下

#include <stdio.h>

/*********************************
* 方法1: 第一维的长度可以不指定 *
* 但必须指定第二维的长度 *
*********************************/

void print_a(int a[][5], int n, int m)
{
    
    
    int i, j;
    
    for(i = 0; i < n; i++)
    {
    
    
        for(j = 0; j < m; j++)
            printf("%d ", a[i][j]);
        
        printf("\n");
    }
}

/*****************************************
*方法2: 指向一个有5个元素一维数组的指针 *
*****************************************/
void print_b(int (*a)[5], int n, int m)
{
    
    
    int i, j;
    
    for(i = 0; i < n; i++)
    {
    
    
        for(j = 0; j < m; j++)
            printf("%d ", a[i][j]);
        printf("\n");
    }
}

/***********************************
*方法3: 利用数组是顺序存储的特性, *
* 通过降维来访问原数组! *
***********************************/
void print_c(int *a, int n, int m)
{
    
    
    int i, j;
    
    for(i = 0; i < n; i++)
    {
    
    
        for(j = 0; j < m; j++)
            printf("%d ", *(a + i*m + j));
        
        printf("\n");
    }
}
int main(void)
{
    
    
    int a[5][5] = {
    
    {
    
    1, 2}, {
    
    3, 4, 5}, {
    
    6}, {
    
    7}, {
    
    0, 8}};
    
    printf("\n方法1:\n");
    print_a(a, 5, 5);
    
    printf("\n方法2:\n");
    print_b(a, 5, 5);
    
    printf("\n方法3:\n");
    print_c(&a[0][0], 5, 5);
    
    
    return 0;
}

输出结果


方法1:
1 2 0 0 0 
3 4 5 0 0 
6 0 0 0 0 
7 0 0 0 0 
0 8 0 0 0 

方法2:
1 2 0 0 0 
3 4 5 0 0 
6 0 0 0 0 
7 0 0 0 0 
0 8 0 0 0 

方法3:
1 2 0 0 0 
3 4 5 0 0 
6 0 0 0 0 
7 0 0 0 0 
0 8 0 0 0 

猜你喜欢

转载自blog.csdn.net/ManiacLook/article/details/124721648