本题要求实现一个在数组中查找指定元素的简单函数。
函数接口定义:
int search( int list[], int n, int x );
其中list[]是用户传入的数组;n(≥0)是list[]中元素的个数;x是待查找的元素。如果找到
则函数search返回相应元素的最小下标(下标从0开始),否则返回−1。
输入样例1:
5
1 2 2 5 4
2
输出样例1:
index = 1
输入样例2:
5
1 2 2 5 4
0
输出样例2:
Not found
程序:
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#define MAXN 10int 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);elseprintf("Not found\n");return 0;
}
int search(int list[], int n, int x)
{int i, flag = 0;for (i = 0; i < n - 1; i++){if (list[i] == x){flag = 1;return i;}}if (flag == 0){return -1;}
}
效果如下: