| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 931 人关注过本帖
标题:[求助]基 本 的 折 半 查 找 法
取消只看楼主 加入收藏
ysgyh
Rank: 1
等 级:新手上路
帖 子:17
专家分:0
注 册:2006-2-4
收藏
 问题点数:0 回复次数:5 
[求助]基 本 的 折 半 查 找 法

各位高手,不知是我的C++有问题,还是编的有问题,总是在运行后输入值时出现错误,还请多多指教,
另外如果运行成功的话,请在你们的机子上输入一下2和3看是否能查出在数组 中的位置,谢谢!!!!!
/**********************************************************
基 本 的 折 半 查 找 法
*********************************************************/
#include <iostream.h>
void main()
{
int a[6]={2,3,9,24,89,98};
int mid,max,min,t;
mid=0;
max=5;
cout<<"请输入要找的数:";
cin>>t;
while(max>min)
{
mid=(max+min)/2;
if(a[mid]==t)
{cout<<"数组中位置是"<<mid<<endl;
break;
}
if(a[mid]>t)
max=mid;
if(a[mid]<t)
min=mid;
}
cout<<"您查找的数不在该数组内"<<endl;
}

搜索更多相关主题的帖子: include 
2006-02-05 16:11
ysgyh
Rank: 1
等 级:新手上路
帖 子:17
专家分:0
注 册:2006-2-4
收藏
得分:0 

我第六行就是写的0啊, 改完后你运行的可以了吗,2和3都能查出来吗?


我的还是不行啊.看来是我的C++有问题,谢谢你了

[此贴子已经被作者于2006-2-5 17:56:09编辑过]

2006-02-05 17:32
ysgyh
Rank: 1
等 级:新手上路
帖 子:17
专家分:0
注 册:2006-2-4
收藏
得分:0 

柳儿姐谢谢了,我这运行成功了,是我太马虎了,另外我刚学的C++所以再多问一下
using namespace std 干什么用的

2006-02-05 18:59
ysgyh
Rank: 1
等 级:新手上路
帖 子:17
专家分:0
注 册:2006-2-4
收藏
得分:0 
6楼的朋友你的程序有点错误,如下::
int a[6]={2, 3, 9, 24, 89, 98};
int iy;//少逗号
cin>>y;
for (int i=0; i<6; i++)//括号内不要有int
{
if(y==a[i])
{
cout<<"数组中位置是"<<i<<endl;
break;
}
}
cout<<"未在数组中发现此数字"<<endl
还有你的程序运行2,3,9.....时,虽然能找出位置,但是总会有"未在数组中发现此数字"
我建议你看一下柳儿姐的程序,很有帮助.
谢谢你的回复!!!!!!!!!
2006-02-05 19:08
ysgyh
Rank: 1
等 级:新手上路
帖 子:17
专家分:0
注 册:2006-2-4
收藏
得分:0 
我也不知道啊,我给版主发过邮件去了,他还没回呢,他回后我再写在这
2006-02-06 10:50
ysgyh
Rank: 1
等 级:新手上路
帖 子:17
专家分:0
注 册:2006-2-4
收藏
得分:0 
哦,谢谢了!
还是有些不懂,我还没学呢,等学了后我想就会明白了..
9楼的程序确实是经典算法啊,我会记下的!!!
谢谢各位朋友们的回贴!!!
2006-02-06 11:20
快速回复:[求助]基 本 的 折 半 查 找 法
数据加载中...
 
   



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

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