码迷,mamicode.com
首页 > 编程语言 > 详细

C++中关于二维数组作为函数参数传递的问题

时间:2015-12-29 06:14:41      阅读:197      评论:0      收藏:0      [点我收藏+]

标签:

在做数据结构迷宫实验的时候,要生成一个二维数组存储迷宫数据,为了保证程序的模块化,将生成部分单独放进一个函数migongsc()里。大致代码如下:

技术分享

 

        问题的关键就集中在了如何将主函数中声明的二维数组migong[8][9]传递到自定义函数中去。

     耗费了一个晚上的时间,我总共整理出了三种办法:

     方法1:模拟编译器寻址(本法来自CSDN博客,原文:

http://blog.csdn.net/jatix/archive/2004/08/29/88150.aspx)。

      大体意思为:将二维数组当作参数的时候,必须指明所有维数大小或者省略第一维的,但是不能省略第二维或者更高维的大小,这是由编译器原理限制的。事实上,编译器是这样处理数组的:

      对于数组 int p[m][n],如果要取p[i][j]的值(i>=0 && i<m && 0<=j && j < n),编译器是这样寻址的,它的地址为:

 

         p + i*n + j;//注意n!!

         这里如果省略了第二维或者更高维的大小,编译器将不知道如何正确的寻址。根据这个思想,我们可以在程序中模拟编译器寻址的方法,具体如下:

技术分享

            方法二:纯朴法:

       由方法一衍生,顾名思义,直接将声明的二维数组的数组名(即首地址)传递到自定义函数中。但要注意,在函数定义中必须指明第二维的维度!

技术分享

           方法三:二维数组一维化

        C++中的数组和VB等语言中的数组实例化的方式不一样,多维数组可以说是数组的嵌套,即二维数组中,每一个元素是一个一维数组。建立一个一维数组存储每个子数组(或者说元素数组)的首地址,将该数组传递给自定义函数。个人感觉除了提醒人数组可以嵌套之外。。。是个很蛋疼的办法。。。

  技术分享

       总结:由于C++中不能对数组进行引用(不知道为什么),故而传递多维数组的办法都在指针上打主意。以上三个办法中,第一个办法最具有扩展性,可以实现对数组的先定义,后分配空间的美妙效果(详见原文)。第二种办法简洁明了,符合思维习惯。第三种方法。。。呃。。。。

PS:非要使用引用的话,可以用二维向量代替数组实现,以下为代码:

技术分享

注意二维向量声明时的写法:vector<vector<int> > migong(8);//注意空格!!!

欢迎指正!

C++中关于二维数组作为函数参数传递的问题

标签:

原文地址:http://www.cnblogs.com/LeeZz/p/5084498.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!