我是 C 新手,目前正在研究数组。我想检查某个值是否在数组中,但我遇到了一些问题(不仅在语法方面,而且在理解方面)。
我的目标是有一个我可以调用的函数,给它两个参数——要搜索的值和要搜索的数组——并根据它是否被找到返回一个 0 或 1。
我的方法如下:
#include <stdio.h>
#include <stdlib.h>
int valueinarray(float val, float *arr[]);
int main()
{
float arr[] = {5, 4.5, 4, 3.5, 3, 2.5,};
int test = valueinarray(4.5, *arr[]);
printf("%d", test);
return 0;
}
int valueinarray(float val, float *arr[]){
int i;
for(i = 0; i < sizeof(*arr[]); i++){
if(*arr[i] == val) return 1;
}
return 0;
}
Run Code Online (Sandbox Code Playgroud)
我现在有两个问题,特别是关于语法的问题:
如果我创建一个带有指针作为其参数之一的函数,我是否必须一直在函数内部使用“*arr[]”来引用它?还是“arr[]”甚至“arr”就足够了?
我是否正确理解我无法将整个数组传递给函数所以我改用指针?
此外,我的方法是错误的,我不明白为什么。迭代数组似乎工作得很好,甚至检查某个值是否在其中也有效,问题似乎出在我调用函数的方式上。我读过双指针,这是需要它们的场景吗?如果不是,他们需要什么?
非常感谢。
float arr[] = ...;
Run Code Online (Sandbox Code Playgroud)
声明一个名为 arr 的浮点数数组(因为 [])(因为 float 关键字)。同样在函数声明中:
int valueinarray(float val, float *arr[]);
Run Code Online (Sandbox Code Playgroud)
意味着第二个参数是一个指向数组(因为[])的指针(因为*),这根本不是你所需要的。您只需要接受一个数组:
int valueinarray(float val, float arr[]);
Run Code Online (Sandbox Code Playgroud)
然而,在 C 中,这相当于float *arr- 指向我们从中读取浮点数的内存中某个地址的指针。
它不能保证那里实际保存有任何浮动,我们也不知道有多少。您必须自己跟踪这一点。因此该函数应该接受另一个参数 - 数组的大小。这是 Marco Bonelli 的解决方案,它是正确的:
bool valueinarray(float val, float *arr, size_t n) {
for(size_t i = 0; i < n; i++) {
if(arr[i] == val)
return true;
}
return false;
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
51106 次 |
| 最近记录: |