| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 729 人关注过本帖
标题:二分法查找程序,帮忙找找错
只看楼主 加入收藏
月岚の朝歌
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2011-9-25
结帖率:0
收藏
已结贴  问题点数:20 回复次数:3 
二分法查找程序,帮忙找找错
#include <stdio.h>
int binary_search(int [],int,int);
int main()
{
#define kongjian 81
    int nums [kongjian];
    int n=0;
    int key;
    printf("输入数据:\n");
    while(scanf("%d",&nums[n])==1)
    {n++;}
    printf("输入要查找的数:\n");
    scanf("d%",&key);
    if(binary_search>0)

    printf("位置是第%d个\n",binary_search);
   
    if(binary_search==-1)

    printf("没有找到\n");
   
    return 0;
}
int binary_search(int nums[],int key,int n )
{    int mid,front=0,back=n-1;
     while (front<=back)
     {mid=(front+back)/2;
     if(nums[mid]==key)
         return mid;
     if (nums[mid]<key)
         front = mid+1;
     else back = mid-1;
     }
     return -1;
}
搜索更多相关主题的帖子: kongjian include return 二分法 
2011-09-25 09:46
A13433758072
Rank: 11Rank: 11Rank: 11Rank: 11
来 自:广东潮州
等 级:小飞侠
威 望:1
帖 子:1182
专家分:2784
注 册:2010-7-22
收藏
得分:7 
#define kongjian 81放错地方了 把



if(binary_search>0)?????



一般遇到第二次读取缓冲区,先清空下

[ 本帖最后由 A13433758072 于 2011-9-25 09:58 编辑 ]

一步一个脚印...............................默默地前进.....
诚邀乐于解答c菜鸟问题,的热心网友加入,  QQ群38490319
2011-09-25 09:51
afant
Rank: 2
等 级:论坛游民
帖 子:3
专家分:20
注 册:2011-9-25
收藏
得分:7 
函数一个实参都没有怎么会对呀??
2011-09-25 10:10
拾忆
Rank: 2
等 级:论坛游民
帖 子:23
专家分:63
注 册:2011-9-23
收藏
得分:7 
很多错误!!
1  #define kongjian 81应放在开头更规范;
2  scanf("d%",&key);应改为scanf("%d",&key);
3  if(binary_search>0) printf("位置是第%d个\n",binary_search);if(binary_search==-1)三句都错,没有接收实参;
4   while(scanf("%d",&nums[n])==1) {n++;}照你这么写只能接收1了,因为只有1条件才满足,n才会计数累加,
    如果输入不是1,那循环就结束了,只接收到了一个数!





2011-09-25 11:41
快速回复:二分法查找程序,帮忙找找错
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.028231 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved