C语言定义一个函数如果含有数组

比如定义成voidmin(inta[],intx)后面为什么要有intx,这个x什么意思,比如我定义一个函数合并2个数组里面的值可以定义为voidmin(inta[],i... 比如定义成 void min(int a[],int x)后面为什么要有int x,这个x什么意思,比如我定义一个函数合并2个数组里面的值可以定义为 void min(int a[],int b[])么,这样定义是错误的么。 展开
 我来答
Xmaples
2013-05-12 · 超过51用户采纳过TA的回答
知道小有建树答主
回答量:118
采纳率:0%
帮助的人:98.9万
展开全部
我猜你想问的是为什么好多函数的参数如果有个数组后面总喜欢有个int型参数,因为C里面的数组(如上面的int[] a)不像Java, a不携带数组的长度信息,而遍历数组需要知道数组长度信息故传入长度x. 而Java里由于数组也是一种类型,所以携带的信息较多,含有长度(公有字段length). 在定义时参数int x随你要不要,但如果你想合并a,b你肯定至少要遍历一个数组(如b)然后把数据追加到另一个数组里(如a),那你就得知道b的长度. (如果你实在不想多传长度,你可以考虑sizeof运算符,但如果a不是数组而是指针sizeof也没辙.)
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式