鱼C论坛

 找回密码
 立即注册
查看: 1591|回复: 6

[已解决]指针与函数综合应用---数组元素值查找问题

[复制链接]
发表于 2020-12-18 18:54:43 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
【问题描述】数组元素值查找问题:输入一个整数,在数组中查找是否存在该数,若存在则显示其所在的数组下标位置,否则显示NOEXIST,查找使用search函数实现, 试完成空缺处的程序代码。
【输入形式】输入待查找的数据
【输出形式】输出查找结果(数组下标值或NOEXIST)
【样例输入】35
【样例输出】index=2
【样例说明】
【评分标准】
#include <stdio.h>
#define N 10
int search(int *p,int x,int n)
{     
     
}
int main()
{    int indx,m,a[N]={10,20,35,40,43,44,45,50,51,60};
     scanf("%d",&m);
      
     if(indx>=0)
        printf("index=%d\n",indx);
     else
        printf("NOEXIST\n");
     return 0;
}




我自己写的代码:
#include <stdio.h>
#define N 10
int search(int *p,int x,int n)
{     
   int ;
   for(n=0;n<10;n++)
   {
           if(*(p+n)==x)
             {
                     break;
                 }             
         }
         return n;  
}
int main()
{    int indx,m,a[N]={10,20,35,40,43,44,45,50,51,60};
     scanf("%d",&m);
     search(a,m,indx);  
     if(indx>=0)
        printf("index=%d\n",indx);
     else
        printf("NOEXIST\n");
     return 0;
}

输出结果一直是0;
麻烦大佬指点迷津,谢谢啦
最佳答案
2020-12-18 22:04:16
本帖最后由 风过无痕1989 于 2020-12-18 22:15 编辑
#include <stdio.h>
#define N 10
int search(int *p,int x,int n)
{     
   int i;
   for(i=0;i<n;i++)
   {
        if(*(p+i)==x)
        {
            break;
        }             
    }
         return i;  
}
int main()
{    
    int index,m,a[N]={10,20,35,40,43,44,45,50,51,60};
    scanf("%d",&m);
    index = search(a,m,N);   //你的数组长度是N,不能用n 去调用函数 
    if(index>=0)
        printf("index=%d\n",index);
    else
        printf("NOEXIST\n");
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-12-18 22:04:16 | 显示全部楼层    本楼为最佳答案   
本帖最后由 风过无痕1989 于 2020-12-18 22:15 编辑
#include <stdio.h>
#define N 10
int search(int *p,int x,int n)
{     
   int i;
   for(i=0;i<n;i++)
   {
        if(*(p+i)==x)
        {
            break;
        }             
    }
         return i;  
}
int main()
{    
    int index,m,a[N]={10,20,35,40,43,44,45,50,51,60};
    scanf("%d",&m);
    index = search(a,m,N);   //你的数组长度是N,不能用n 去调用函数 
    if(index>=0)
        printf("index=%d\n",index);
    else
        printf("NOEXIST\n");
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2020-12-18 22:07:57 | 显示全部楼层
本帖最后由 jackz007 于 2020-12-18 22:10 编辑
#include <stdio.h>

#define N 10

int search(int * p , int x , int n)
{     
        int  i , r            ;
        for(r = -1 , i = 0 ; i < n ; i ++) {
                if(* (p + i) == x) {
                        r = i ;
                        break ;        
                }
        }
        return r              ;
}

int main()
{    int indx , m , a[N] = {10,20,35,40,43,44,45,50,51,60} ;
     scanf("%d" , & m)                                     ;
     indx = search(a , m , N)                              ;
     if(indx >= 0) printf("index=%d\n" , indx)             ;
     else printf("NOEXIST\n")                              ;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2020-12-19 17:18:57 | 显示全部楼层

int search(int *p,int x,int n)   这个定义是题目已经给出来的,从哪里得知他定义的是 数组中已有的数值的个数 。我以为调用search函数之后,indx就能代替n。emmmm可能表达得有点混乱哈哈哈啊,也就是怎么知道n定义的是哪个?可以给我讲一下原因吗 谢谢啦
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-19 18:24:41 | 显示全部楼层
富贵要加油 发表于 2020-12-19 17:18
int search(int *p,int x,int n)   这个定义是题目已经给出来的,从哪里得知他定义的是 数组中已有的数值 ...

int search(int *p,int x,int n) 这个定义是题目给出的,一般情况,我们不能去改变它。很明显,int *p 是指向数组的,另外两个都是 int 型,用哪个将数组长度传给函数都是没有问题的,也就是说,用 n 传递 要查找的数也是正确的,但是我们习惯于用 i、j、k 来作循环变量,用 m、n 来表示整数,用 x、y、z 来表示未知的数。要查找的数有点未知的意思,所以在程序中,我就用 x 来传递要查找的数,用 n 来传递数组长度了。

在 定义这里知道数组的长度,因为 int a[N]={10,20,35,40,43,44,45,50,51,60}; 数组中方括号里就是数组的长度呀
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-12-23 18:25:34 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-12-23 18:26:12 | 显示全部楼层

已经弄清楚了 非常感谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-10 16:48

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表