鱼C论坛

 找回密码
 立即注册
查看: 3801|回复: 13

折半查找在C_free中运行不出来 求救

[复制链接]
发表于 2012-11-13 10:34:06 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 番茄 于 2012-11-14 23:38 编辑

# include <stdio.h>
int bin_search(int key[], int n, int k)
{
        int low = 0, high = n - 1, mid;
        while (low <= high)
        mid = (low + high)/2;
        {
                if (key[mid] = k)
                {
                        return mid;
                }
                else if (k > key[mid])
                {
                        low = mid + 1;
                }
                else
                {
                        high = mid - 1;
                }
               
        }
        return -1;
}
int main(void)
{
        int a[10]={11, 22, 33 ,55 , 66, 99, 42, 16, 98, 72};
        printf ("the contents of the Arrsy a[10] are \n");
        int i;
        int c;
        
        for (i = 0; i < 10; i++)
        printf ("%d ",a);        
        int k;
        printf ("\n请输入要查询的数字");
        scanf ("%d", &k);
        c = bin_search(a, 10, k);
    if (-1 != c)
    {
            printf ("%d", c);
        }
        else
        {
                printf ("chazhaoshibai");
        }
        
        return 0;
        
}

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2012-11-14 08:46:59 | 显示全部楼层

回帖奖励 +2 鱼币

折半查找必须是有序的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2012-11-14 08:48:25 | 显示全部楼层
mid = .. 应该在while循环里面

评分

参与人数 1鱼币 +2 收起 理由
番茄 + 2

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
 楼主| 发表于 2012-11-14 21:16:00 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
 楼主| 发表于 2012-11-14 21:16:31 | 显示全部楼层
wangyexin 发表于 2012-11-14 08:46
折半查找必须是有序的

呵呵  粗心了  嘿嘿
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
 楼主| 发表于 2012-11-14 21:25:41 | 显示全部楼层
wangyexin 发表于 2012-11-14 08:46
折半查找必须是有序的

嗯  呵呵  
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2013-8-17 08:02:47 | 显示全部楼层

回帖奖励 +2 鱼币

呵呵,不错啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-8-17 11:54:01 | 显示全部楼层
不错啊,呵呵
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-8-17 15:54:41 | 显示全部楼层

回帖奖励 +2 鱼币

代码有问题
#include<stdio.h>
void binsearch(int k,int a[],int n)
{
    int mid,low,high,count = 0,count1 = 0;
        low = 0;
    high = n-1;
        while(low <= high) //一定要是小于等于 次奥 啊 麻痹的老子调试了一晚上
        {
            count++;
                mid = (low+high)/2;
        if(k < a[mid])
                {
                    high = mid-1;
                }
                else if(k > a[mid])
                {
                    low = mid+1;
                }
        else if(k == a[mid])
                {   
                    printf("查找成功!%d是序列的第%d个数\n",k,mid+1);
                        count1++;
                        break;
                }
        }
    if(count1 == 0)
        {
            printf("查找失败,不存在这个数!");
        }
}
void main()
{
    int i,j,k;
        int a[100];
        printf("请输入序列长度:");
        scanf("%d",&k);
        printf("\n");
        printf("请有序输入一个序列:");
    for(i = 0;i < k;i++)
        {
            scanf("%d",&a[i]);
        }
        printf("\n");
        printf("请输入要查找的数:");
    scanf("%d",&j);
        binsearch(j,a,k);
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-8-17 18:05:36 | 显示全部楼层

回帖奖励 +2 鱼币

我只是路过打酱油的。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-8-20 10:11:41 | 显示全部楼层
路过打酱油的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-8-26 20:26:09 | 显示全部楼层
学习了啊,呵呵
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-8-26 21:26:09 | 显示全部楼层

回帖奖励 +2 鱼币

{11, 22, 33 ,55 , 66, 99, 42, 16, 98, 72};
这组数一看就不行,必须有规律,降序||升序
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-9-2 21:43:31 | 显示全部楼层
{:1_1:}厉害{:1_1:}厉害{:1_1:}厉害
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-18 21:39

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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