6-1 在数组中查找指定元素
分数 35
作者 张泳
单位 浙大城市学院
本题要求实现一个在数组中查找指定元素的简单函数。
函数接口定义:
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;
}
/* 你的代码将被嵌在这里 */
输入样例1:
5
1 2 2 5 4
2
输出样例1:
index = 1
输入样例2:
5
1 2 2 5 4
0
输出样例2:
Not found
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
代码
int search( int list[], int n, int x ) {
int i;
for(i = 0; i < n; i++) {
if(list[i] == x) {
return i;
}
}
return -1;
}
6-2 二分法查找
分数 35
作者 王跃萍
单位 东北石油大学
函数为二分法查找key值。数组中元素已递增排序,若找到key则返回对应的下标,否则返回-1。
函数接口定义:
int fun(int a[],int n,int key);
其中 a
、n
和 key
都是用户传入的参数。函数用二分法查找key
值。数组 a
中的n
个元素已递增排序,若找到key
则返回对应的下标,否则返回-1数。
裁判测试程序样例:
#include <stdio.h>
int fun(int a[],int n,int key);
int main()
{
int a[10]={1,2,3,4,5,6,7,8,9,10}, b,c;
b=4;
c=fun(a,10,b);
if(c==-1)printf("not found");
else printf("position %d\n",c);
return 0;
}
/* 请在这里填写答案 */
输出样例:
position 3
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
代码
int fun(int a[], int n, int key) {
int left = 0, right = n - 1, mid;
while (left <= right) {
mid = left + (right - left) / 2;
if (a[mid] == key) {
return mid;
} else if (a[mid] < key) {
left = mid + 1;
} else {
right = mid - 1;
}
}
return -1;
}