C语言编程题:初始化一个已排序的整型数组,用二分法查找其中是否存在常量5,如有,打印其下标。

C语言编程题:初始化一个已排序的整型数组,用二分法查找其中是否存在常量5,如有,打印其下标。请回答的大神尽量用容易看懂的形式…我是个初学者…... C语言编程题:初始化一个已排序的整型数组,用二分法查找其中是否存在常量5,如有,打印其下标。请回答的大神尽量用容易看懂的形式…我是个初学者… 展开
 我来答
xoaxa
2016-12-13 · TA获得超过8610个赞
知道大有可为答主
回答量:6415
采纳率:72%
帮助的人:3483万
展开全部
#include <stdio.h>
#include <string.h>

void Sort(int a[],int n) {
int i,j,k;
int num;
for(i = 0; i < n - 1; ++i) {
k = i;
for(j = i + 1; j < n; ++j)
if(a[k] > a[j]) k = j;
if(k != i) {
num = a[k];
a[k] = a[i];
a[i] = num;
}
}
}

int BinFind(int a[],int n,int num) {
int mid,start = 0;
int end = n - 1;
if(a[start] == num) return start;
if(a[end] == num) return end;
while(start < end) {
mid = (start + end)/2;
if(a[mid] == num) return mid;
else if(a[mid] > num) end = mid - 1;
else start = mid + 1;
}
return -1;
}

int main() {
int a[] = {3,6,9,4,8,7,21,12,23,24,25,2,92,10,11,19,5};
int pos,i,num = 5;
int n = sizeof(a)/sizeof(a[0]);
pos = BinFind(a,n,num);
printf("排序前:\n");
for(i = 0; i < n; ++i) printf("%d ",a[i]);
printf("\n");
if(pos >= 0) printf("s[%d] = %d\n",pos,num);
else printf("没找到数值%d,对不起。\n",num);
Sort(a,n);
printf("排序后:\n");
for(i = 0; i < n; ++i) printf("%d ",a[i]);
printf("\n");
pos = BinFind(a,n,8);
if(pos >= 0) printf("a[%d] = %d\n",pos,8);
else printf("没找到数值%d,对不起。\n",8);
return 0;
}
zamswi
2016-12-13 · TA获得超过212个赞
知道小有建树答主
回答量:224
采纳率:33%
帮助的人:156万
展开全部
#include <stdio.h>
int find(int array[], int length, int x) {
    int left = 0, right = length - 1; 
    while(left <= right) {
        int middle = (left + right) / 2;
        if (array[middle] == x) {
            return middle;
        } else if (array[middle] > x) {
            right = middle - 1;
        } else if (array[middle] < x) {
            left = middle + 1;
        }
    }
    return -1;
}
void main() {
    int array[] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 }, index;
    index = find(array, sizeof(array) / sizeof(int), 5);
    printf("%d\n", index);
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式