在C++编程中,我们经常将数组作为参数传递到另一个函数,数组的维数不同,传递方式也不同,此处将作一个总结,包括一维静态、动态数组,二维静态、动态数组。

一,一维数组(静态、动态一维数组)

1, 一维数组寻址形式:num[i]的地址:num+i,因此一维数组作为参数传递时候,只需要用数组名作为参数即可。

shuchu(num)
void shuchu(int num[])

2,一维数组实例:

#include <iostream>
using namespace std; void ces1(int *num)
{
for (int i = ; i < ; i++){
cout << num[i] << endl;
}
} void ces2(int *num, int m)
{
for (int i = ; i < m; i++){
cout << num[i] << endl;
}
} int main()
{
int num1[];
for (int i = ; i < ; i++){
num1[i] = i;
}
ces1(num1); int k = ;
int *num2 = new int[k];
for (int i = ; i < k; i++){
num2[i] = i + ;
}
ces2(num2, k);
delete[] num2; return ;
}

二,二维数组

1,静态二维数组利用数组名和第二维大小作为参数

(1)二维数组如下int num[M][N],二维数组寻址形式:num[i][j]的地址:num+i*N+j。由此可知二维数组作为参数传递时候,除了数组名作为参数,还需要数组第二维的大小,第一维随意。

二维数组实参:

shuchu(num);

二维数组形参二种形式皆可:

void shuchu(num[][]);
void shuchu(num[][]);

(2)二维数组实例:

#include <iostream>
using namespace std; void ces(int num[][]) //这样可以
//void ces(int num[][5]) //这样可以
//void ces(int num[5][]) //这样不可以
{
for (int i = ; i < ; i++){
for (int j = ; j < ; j++){
cout<<num[i][j]<<" ";
}
cout<<endl;
}
} int main()
{
int num[][];
for (int i = ; i < ; i++){
for (int j = ; j < ; j++){
num[i][j] = i * j;
}
}
ces(num);
return ;
}

2,动态二维数组利用二维指针传递数组参数

(1),我们知道动态二维数组的第一维和第二维都是变量,因此我们利用"数组名和二维大小作为形参"这种方式失效,此处必须利用二维指针。

二维数组实参:

shuchu(num);

二维指针作为形参:

void shuchu(int **num)

二维数组在子函数中使用方式:

num[i][j]即可

3,静态二维数组也可用二维指针。

二维数组实参:

shuchu((int **)num);     //此处需要强制转化

二维指针作为形参:

void shuchu(int **num)

二维数组在子函数中使用方式:

这样是不对的:  num[i][j]
必须这样: *((int *)num+*i+j) 或
((int *)num+*i)[j]

4,下面给出了二维静态数组和动态数组的两个实例,有两处不同,在程序中用红色标识了

//二维静态数组
#include <iostream>
using namespace std; void ces(int **num)
{
for (int i = ; i < ; i++){
for (int j = ; j < ; j++){
cout<<*((int *)num+*i+j)<<" "; //这样可以
// cout<<((int *)num+5*i)[j]<<" "; //这样可以
// cout<<num[i][j]<<" "; //这样不可以
}
cout<<endl;
}
} int main()
{
int num[][];
for (int i = ; i < ; i++){
for (int j = ; j < ; j++){
num[i][j] = i * j;
}
}
ces((int **)num); //这样可以
// ces(num); //这样不可以
return ;
}
//二维动态数组
#include <iostream>
using namespace std; void ces(int **num, int m, int n)
{
for (int i = ; i < m; i++){
for (int j = ; j < n; j++){
// cout<<*((int *)num+5*i+j)<<" "; //这样不行
// cout<<((int *)num+5*i)[j]<<" "; //这样不行
cout<<num[i][j]<<" "; //这样可以
}
cout<<endl;
}
} int main()
{
int m = , n = , i, j;
int **num = new int*[m];
for (i = ; i < m; i++)
{
num[i] = new int[n];
}
for (i = ; i < m; i++){
for (j = ; j < n; j++){
num[i][j] = i * j;
}
}
ces(num, m, n); //这样可以 // ces((int **)num, m, n); //这样可以
for (i = ; i < m; i++)
{
delete[] num[i];
}
delete[] num;
return ;
}

C++中将二维数组(静态的和动态的)作为函数的参数传递的更多相关文章

  1. C语言中将二维数组作为函数参数来传递

    c语言中经常需要通过函数传递二维数组,有三种方法可以实现,如下: 方法一, 形参给出第二维的长度. 例如: #include <stdio.h> void func(int n, char ...

  2. PHP中将二维数组 转换成字符串

    function arr_to_str($arr) { $t ='' ; foreach ($arr as $v) { $v = join(",",$v); // 可以用implo ...

  3. C语言 二维数组(指针)动态分配和释放(转)

    C 二维数组(指针)动态分配和释放 先明确下概念: 所谓32位处理器就是一次只能处理32位,也就是4个字节的数据,而64位处理器一次就能处理64位,即8个字节的数据.如果我们将总长128位的指令分别按 ...

  4. c 二维数组动态分配和释放

    c动态语言 函数声明的头文件在<stdlib.h>里 使用malloc函数为字符串分配内存 -->记得释放内存 free() #include <stdio.h> #in ...

  5. 【Java学习笔记之八】java二维数组及其多维数组的内存应用拓展延伸

    多维数组声明 数据类型[][] 数组名称; 数据类型[] 数组名称[]; 数据类型数组名称[][]; 以上三种语法在声明二维数组时的功能是等价的.同理,声明三维数组时需要三对中括号,中括号的位置可以在 ...

  6. 【Java学习笔记之九】java二维数组及其多维数组的内存应用拓展延伸

    多维数组声明 数据类型[][] 数组名称; 数据类型[] 数组名称[]; 数据类型数组名称[][]; 以上三种语法在声明二维数组时的功能是等价的.同理,声明三维数组时需要三对中括号,中括号的位置可以在 ...

  7. Java编程基础阶段笔记 day06 二维数组

    二维数组 笔记Notes 二维数组 二维数组声明 二维数组静态初始化与二位初始化 二维数组元素赋值与获取 二维数组遍历 二维数组内存解析 打印杨辉三角 Arrays工具类 数组中常见的异常 二维数组 ...

  8. C#学习笔记04--排序/查找/二维数组/交叉数组

    一. 冒泡排序(重点) 思路:  每次比较把较小的放在前面, 大的放到后面; 图解:下图是最坏情况下的排序 ` 冒泡排序m个元素, 就有(m-1)趟排序, 第一趟m-1次, 第二趟 m-2次....  ...

  9. 二维数组及Arrays工具类

    1.二维数组 概念: 数组中的每一个元素类型都是一维数组 二维数组初始化方式: 静态初始化: 格式: 元素类型[][] 数组名 = new 元素类型[][]{{一维数组1},{一维数组2},{一维数组 ...

随机推荐

  1. MySql的数据分页的Sql

    一:分页需求: 客户端通过传递start(页码),limit(每页显示的条数)两个参数去分页查询数据库表中的数据,那我们知道MySql数据库提供了分页的函数limit m,n,但是该函数的用法和我们的 ...

  2. geoserver 问题解决

    GeoServer的8080端口被占用了怎么办?如何修改GeoServer的端口? GeoServer管理页面的登陆地址正常情况下为:http://localhost:8080/geoserver/w ...

  3. DNA binding motif比对算法

    DNA binding motif比对算法 2012-08-31 ~ ADMIN 之前介绍了序列比对的一些算法.本节主要讲述motif(有人翻译成结构模式,但本文一律使用基模)的比对算法. 那么什么是 ...

  4. socket多文件发送(压缩,解压)

    .客户端代码 public static void FileMoveInVirtualMachineForCompressor() { var obj = new object(); string i ...

  5. 关闭文件描述符-close

    头文件:#include<unistd.h> 原型:int close(int fd); 返回值:成功返回0,失败返回-1.

  6. 系统调用方式文件编程-open

    通过Linux系统调用函数编写应用程序,该应用程序实现文件的复制功能 文件描述符--在Linux系统中,所有打开的文件也对应一个数字,这个数字由系统来分配. 1.打开文件--open 头文件:#inc ...

  7. 2018.07.20 atcoder Largest Smallest Cyclic Shift(贪心)

    传送门 题意:给你x个a,y个b,z个c,显然这些字符可以拼成若干字符串,然后求这些字符串中最小表示法表示出来的最大的那一个. 解法:贪心思想,用multiset维护现在拼成的字串,每次取一个最小的和 ...

  8. DevExpress gridcontrol Master-Detail绑定到对象类型

    数据库:C_ProductPlan ,C_ProductPlanItemDTO定义:(实现每个计划条目-Master,对应多个ProcessInfo-Detail) [DataContract] [S ...

  9. docker入门实战

    基本概念 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上. Docker是一个重新定义了程序开发测试.交付和 ...

  10. Tomcat & SVN

    1. Tomcat简介 tomcat是一个web服务器,类似nginx,apache的http nginx,http只能处理html等静态文件(jpg) 网页分为静态网页(以.html或者.htm结尾 ...