题目描述
本题要求实现一个在数组中查找指定元素的简单函数。
函数接口定义:
int search( int list[], int n, int x );
其中list[]是用户传入的数组;n(≥0)是list[]中元素的个数;x是待查找的元素。如果找到
则函数search返回相应元素的最小下标(下标从0开始),否则返回-1。
裁判测试程序样例:
#include <stdio.h>
#define MAXN 10
int search( int list[], int n, int x );
int main()
{
int i, index, n, x;
int a[MAXN];
scanf("%d", &n);
for( i = 0; i < n; i++ )
scanf("%d", &a[i]);
scanf("%d", &x);
index = search( a, n, x );
if( index != -1 )
printf("index = %d\n", index);
else
printf("Not found\n");
return 0;
}
/* 你的代码将被嵌在这里 */
输入
5
1 2 2 5 4
0
输出
Not found
样例输入
5
1 2 2 5 4
2
样例输出
index = 1
分析
又是给出主函数的题<( ̄ ﹌  ̄)> ,这是在比打字速度吗╮(╯﹏╰)╭
#include <stdio.h>
int search(int list[],int n,int x);
int main()
{
int i,id,n,x;
int a[10];
scanf("%d",&n);
for(i = 0;i < n;i++)
{
scanf("%d",&a[i]);
}
scanf("%d",&x);
id = sear(a,n,x);
if(id != -1)
printf("index = %d\n",id);
else
printf("Not found\n");
return 0;
}
int search(int list[],int n,int x) //如果找到一样的值,返回下标,下标是从0开始的,所以返回值不加1
{
int i;
for(i = 0;i < n;i++)
{
if(list[i] == x)
return i;
}
return -1;
}