返回二维数组


#二维数组的返回


确切的说是返回二维数组的指针,二维数组和一位数组稍微有些不同,鉴于一维数组过于简单,博主在此只讲返回二维数组的两种方法。
一如既往的少废话,直接上刑,不,上代码:
##1.返回二维数组的第一行的首地址:

#include <stdio.h>

int *array(void)
{
    static int a[2][2] = {1,2,3,4};
    return *a;//返回二维数组的第一行的首地址
}

int main(void)
{
    int *p;
    p = array();
    int i,j;
    for(i=0;i<4;i++)
    {
    	printf("%d",p[i]);
    }
    printf("\n");
}

不可少的运行,结果如下:

这里写图片描述

##2.第二种方法能返回整个二维数组,操作起来也比较麻烦:

#include <stdio.h>

typedef int (*Point)[2];//用typedef重新定义一个数组指针(为了方便)
Point Two_Array(void)
{
   static int a[2][2] = {1,2,3,4};
   return a;
}

int main(void)
{
	int i,j=0;
    Point p;
	p = Two_Array();
	for(i=0;i<2;i++)
    {
        for(j=0;j<2;j++)
        {
            printf("%d",p[i][j]);
        }
        printf("\n");
    }
}

运行程序,结果如下:
这里写图片描述

C++中返回二维数组有多种方法,以下为你详细介绍: ### 动态开辟二维数组返回指针 可以使用`new`在堆上开辟二维数组,或者使用`malloc`函数,最后返回指向该二维数组的指针。示例代码如下: ```cpp #include <iostream> using namespace std; // 创建二维数组 int** create2DArray(int row, int col) { int **p = new int*[row]; for(int i = 0; i < row; ++i) { p[i] = new int[col]; } return p; } // 销毁二维数组 void destroy2DArray(int **p, int row) { for(int i = 0; i < row; ++i) { delete[] p[i]; } delete[] p; } int main() { int row = 3, col = 4; int **arr = create2DArray(row, col); // 赋值 for(int i = 0; i < row; ++i) { for(int j = 0; j < col; ++j) { arr[i][j] = i * col + j; } } // 输出 for(int i = 0; i < row; ++i) { for(int j = 0; j < col; ++j) { cout << arr[i][j] << " "; } cout << endl; } // 销毁 destroy2DArray(arr, row); return 0; } ``` ### 使用`vector`容器 使用`vector<vector<int>>`来创建二维数组,函数可以直接返回`vector<vector<int>>`对象。示例代码如下: ```cpp #include <iostream> #include <vector> using namespace std; // 创建二维数组 vector<vector<int>> create2DVector(int row, int col) { vector<vector<int>> test(row, vector<int>(col)); // 初始化 for (int i = 0; i < row; i++) { for (int j = 0; j < col; j++) { test[i][j] = i * col + j; } } return test; } int main() { int row = 3, col = 4; vector<vector<int>> arr = create2DVector(row, col); // 输出 for(int i = 0; i < row; ++i) { for(int j = 0; j < col; ++j) { cout << arr[i][j] << " "; } cout << endl; } return 0; } ``` ### 以一维指针形式返回二维数组二维数组看作一维数组进行处理,通过指针和偏移量来访问元素。示例代码如下: ```cpp #include <iostream> using namespace std; // 打印二维数组 void Print(int* M, int row, int col) { for (int i = 0; i < row; i++) { for (int j = 0; j < col; j++) { cout << *((M + i * col) + j) << "\t"; } cout << endl; } } // 返回包含每行最大值和其列索引的二维数组 int** Max(int* M, int row, int col) { int** data = (int**)malloc(sizeof(int*) * row); for (int i = 0; i < row; i++) data[i] = (int*)malloc(sizeof(int) * 2); for (int i = 0; i < row; i++) { int max = *(M + i * col); for (int j = 0; j < col; j++) { if (max < *(M + i * col + j)) { max = *(M + i * col + j); data[i][0] = max; data[i][1] = j; } } } return data; } int main() { int a[2][3] = { 1, 2, 3, 4, 5, 6 }; Print((int*)a, 2, 3); int** data = Max((int*)a, 2, 3); for(int i = 0; i < 2; i++) { for (int j = 0; j < 2; j++) { cout << data[i][j] << " "; } cout << endl; } // 释放内存 for(int i = 0; i < 2; i++) { free(data[i]); } free(data); return 0; } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

追代码的人

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值