曲径通幽论坛

 找回密码
 立即注册
搜索
查看: 3919|回复: 0
打印 上一主题 下一主题

二分法查找一维数组

[复制链接]

4918

主题

5880

帖子

3万

积分

GROAD

曲径通幽,安觅芳踪。

Rank: 6Rank: 6

积分
34397
跳转到指定楼层
楼主
发表于 2009-9-11 12:02:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
代码:
#include <stdio.h>
#include <stdlib.h>

int find_number (int *p, int num, int val);

int main()
{
        int a [15] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15};
        int val;
        int *p = a;
        int num = 15;
        int ret;

        printf ("Input a number which want to find: ");

        scanf ("%d", &val);

        ret = find_number (p, num, val);

        if (ret == -1) {
                printf ("Can not find out the number\n");
                exit (1);
        }
        printf ("find out the number at array position: %d \n", ret);
        return (0);
}

int find_number (int *p, int num, int val)
{
        int high = num;
        int low = 0;
        int mid;

        while (low <= high) {
                mid = (low + high) / 2;

                if (val == *(p + mid))
                        return (mid);

                if (val > *(p + mid))
                        low = mid + 1;

                if (val < *(p + mid))
                        high = mid - 1;

        }
        return (-1);
}
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|曲径通幽 ( 琼ICP备11001422号-1|公安备案:46900502000207 )

GMT+8, 2025-6-18 01:18 , Processed in 0.082007 second(s), 22 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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