C++中将二维数组(静态的和动态的)作为函数的参数传递
在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++中将二维数组(静态的和动态的)作为函数的参数传递的更多相关文章
- C语言中将二维数组作为函数参数来传递
c语言中经常需要通过函数传递二维数组,有三种方法可以实现,如下: 方法一, 形参给出第二维的长度. 例如: #include <stdio.h> void func(int n, char ...
- PHP中将二维数组 转换成字符串
function arr_to_str($arr) { $t ='' ; foreach ($arr as $v) { $v = join(",",$v); // 可以用implo ...
- C语言 二维数组(指针)动态分配和释放(转)
C 二维数组(指针)动态分配和释放 先明确下概念: 所谓32位处理器就是一次只能处理32位,也就是4个字节的数据,而64位处理器一次就能处理64位,即8个字节的数据.如果我们将总长128位的指令分别按 ...
- c 二维数组动态分配和释放
c动态语言 函数声明的头文件在<stdlib.h>里 使用malloc函数为字符串分配内存 -->记得释放内存 free() #include <stdio.h> #in ...
- 【Java学习笔记之八】java二维数组及其多维数组的内存应用拓展延伸
多维数组声明 数据类型[][] 数组名称; 数据类型[] 数组名称[]; 数据类型数组名称[][]; 以上三种语法在声明二维数组时的功能是等价的.同理,声明三维数组时需要三对中括号,中括号的位置可以在 ...
- 【Java学习笔记之九】java二维数组及其多维数组的内存应用拓展延伸
多维数组声明 数据类型[][] 数组名称; 数据类型[] 数组名称[]; 数据类型数组名称[][]; 以上三种语法在声明二维数组时的功能是等价的.同理,声明三维数组时需要三对中括号,中括号的位置可以在 ...
- Java编程基础阶段笔记 day06 二维数组
二维数组 笔记Notes 二维数组 二维数组声明 二维数组静态初始化与二位初始化 二维数组元素赋值与获取 二维数组遍历 二维数组内存解析 打印杨辉三角 Arrays工具类 数组中常见的异常 二维数组 ...
- C#学习笔记04--排序/查找/二维数组/交叉数组
一. 冒泡排序(重点) 思路: 每次比较把较小的放在前面, 大的放到后面; 图解:下图是最坏情况下的排序 ` 冒泡排序m个元素, 就有(m-1)趟排序, 第一趟m-1次, 第二趟 m-2次.... ...
- 二维数组及Arrays工具类
1.二维数组 概念: 数组中的每一个元素类型都是一维数组 二维数组初始化方式: 静态初始化: 格式: 元素类型[][] 数组名 = new 元素类型[][]{{一维数组1},{一维数组2},{一维数组 ...
随机推荐
- WCF生成客户端代理对象的两种方法的解释
最近在封装WCF,有一些很好的实践就记录下来,大家可以放心使用,所有代码都已经调试过.如果有高手可以大家探讨一下. 在WCF中有两种不同的方法可以用于创建客户端服务对象,他们分别为: 1. 代理构造法 ...
- gdb 调试带参数程序
在gdb中,运行程序使用r或是run命令. 程序的运行,你有可能需要设置下面四方面的事. 1.程序运行参数. set args 可指定运行时参数.(如:set args 10 20 30 40 50) ...
- SoapUI Script Library
Environment Get active environment via groovy script log.info testRunner.testCase.testSuite.project. ...
- 《JavaScript高级程序设计》笔记
1. 当在函数内部定义了其他函数时,就创建了闭包.闭包有权访问包含函数内部的所有变量. 2. 闭包可以分隔变量空间,不会占用全局空间而造成相互间的干拢.使用闭包可以在JavaScript中模仿块级作用 ...
- 2018.10.15 NOIP训练 水流成河(换根dp)
传送门 换根dp入门题. 貌似李煜东的书上讲过? 不记得了. 先推出以1为根时的答案. 然后考虑向儿子转移. 我们记f[p]f[p]f[p]表示原树中以ppp为根的子树的答案. g[p]g[p]g[p ...
- 2018.09.11 bzoj2208: [Jsoi2010]连通数(bitset+floyd)
传送门 听说正解是缩点+dfs? 直接bitset优化floyd传递闭包就行了.(尽管时间复杂度是假的O(n3/32)" role="presentation" styl ...
- 2018.07.30 cogs2632. [HZOI 2016] 数列操作d(线段树)
传送门 线段树基本操作 区间加等差数列,维护区间和. 对于每个区间维护等差数列首项和公差,易证这两个东西都是可合并的,然后使用小学奥数的知识就可以切掉这题. 代码: #include<bits/ ...
- [GO]kafka的生产者和消费者
生产者: package main import ( "github.com/Shopify/sarama" "fmt" "time" ) ...
- hibernate createQuery和createSQLQuery 查询结果count计算
createQuery 针对hql语句查询 Query query=getSession().createQuery(hql);int result =((Number) query.iterate( ...
- UVa 12003 Array Transformer (分块)
题意:给定一个序列,然后有 m 个修改,问你最后的序列是什么,修改是这样的 l r v p 先算出从 l 到 r 这个区间内的 小于 v 的个数k,然后把第 p 个的值改成 k * u / (r - ...