二分法查找二分法查找 C++
二分法查找 时间:2021-08-04 阅读:(
)
用二分法查找一个已知顺序的数列中的一个数最坏的情况下需要查找多少次?
最坏情况下的查找次数是(log2(n+1))的取整。
最坏情况下查找到最后单个元素才查找结束,因为每次查找取半,所以需要查找(log2(n+1))的整数次。
二分法查找算法的精确度怎么找?谢谢
二分法用来找零点即有个x符合f(X)=0
方法和简单只要你计算能力过关(一定会有大量计算)
1.根据题意,随机找两个定义域内的两个x
如果f(X2)>0 f(X1)<0
则在X1和x2之间有0点
然后在x1和x2之间选一个X3
如果f(X2)*f(X3)<0 则零点在(X2,X3)之间
f(X2)*f(X3)>0则在(X3,X1)之间
同样的道理一直循环下去
知道范围缩窄道题目所给的精确度,则在这范围里随便去一个数如你的范围以缩窄到(0.03,0.05)而题目要求精确度为0.01 那么你随便取个数0.04或0.05作为函数的解
选我吧 打得很辛苦二分法查找 C++
在VC6.0中运行通过。
》代码一:(在代码三中指出了您没注意到的一些问题)》》:
#include<iostream>
using namespace std;
int main(void)
{
int BinSearch(int R[10],int K,int n);
int a[10],x,i,result;
for(i=0;i<10;i++)
cin>>a[i];
cin>>x;
result=BinSearch(a,x,10);
cout<<result<<endl;
return 0;
}
int BinSearch(int R[10],int K,int n)
{ //在有序表R[0..n-1]中进行二分查找,成功时返回结点的位置,失败时返回零
int low=0,high=n-1,mid; //置当前查找区间上、下界的初值
mid=(low+high)/2;
while(low<=high&&R[mid]!=K)
{ //当前查找区间R[low..high]非空
if(R[mid] >K)
high=mid-1; //继续在R[low..mid-1]中查找
if(R[mid] <K)
low=mid+1; //继续在R[mid+1..high]中查找
mid=(low+high)/2;
} //BinSeareh
if(R[mid]==K) return mid; //查找成功返回
else return -1; //当low>high时表示查找区间为空,查找失败
}
其实如果是在10个数中查找的话,参数n完全没必要
》代码二:》》:
#include<iostream>
using namespace std;
int main(void)
{
int BinSearch(int R[10],int K);
int a[10],x,i,result;
for(i=0;i<10;i++)
cin>>a[i];
cin>>x;
result=BinSearch(a,x);
cout<<result<<endl;
return 0;
}
int BinSearch(int R[10],int K)
{ //在有序表R[0..n-1]中进行二分查找,成功时返回结点的位置,失败时返回零
int low=0,high=10-1,mid; //置当前查找区间上、下界的初值
mid=(low+high)/2;
while(low<=high&&R[mid]!=K)
{ //当前查找区间R[low..high]非空
if(R[mid] >K)
high=mid-1; //继续在R[low..mid-1]中查找
if(R[mid] <K)
low=mid+1; //继续在R[mid+1..high]中查找
mid=(low+high)/2;
} //BinSeareh
if(R[mid]==K) return mid; //查找成功返回
else return -1; //当low>high时表示查找区间为空,查找失败
}
》代码三:》》:
如果您想在若干个(也就是您输入的元素个数不固定)你输入的元素中查找一个数,可以加一个参数n,用它传递数组中元素的个数
#include<iostream>
using namespace std;
int main(void)
{
int BinSearch(int R[10],int K,int n);//函数声明,如果定义在main函数之前,可以不要函数声明 具体参照参照xiang__198的代码
int a[100],x,i,result;
int num;
cout<<"您想输入几个数?"<<endl;
cin>>num;
cout<<"请输入"<<num<<"个已经由小到大排好序的数:"<<endl;
for(i=0;i<num;i++)
cin>>a[i];
cout<<"请输入待查找的数:"<<endl;
cin>>x;
result=BinSearch(a,x,num);//由于定义的函数要返回一个函数值,所以在主函数中要定义一个变量来接收这个返回值,数组元素做实参传递的是数组元素的首地址。
故这里的调用写成result=BinSearch(a,x,num);,其中的a代表的是数组的首地址
cout<<"查找结果:"<<endl;
cout<<result<<endl;
return 0;
}
int BinSearch(int R[10],int K,int n)//不能写成int BinSearch(int R[10],int K,n),注意形参不能为一个常量int BinSearch(int R[10],int K,10) 也不对
{ //在有序表R[0..n-1]中进行二分查找,成功时返回结点的位置,失败时返回零
int low=0,high=n-1,mid; //置当前查找区间上、下界的初值
mid=(low+high)/2;
while(low<=high&&R[mid]!=K)//查找区间不为空时,如果查找到,则R[mid]!=K,结束循环,否则缩小查找空间继续查找,你的这里少了一个R[mid]!=K,所以即使查找到,也不会输出查找结果,因为形成了死循环
{ //当前查找区间R[low..high]非空
if(R[mid] >K)
high=mid-1; //继续在R[low..mid-1]中查找
if(R[mid] <K)
low=mid+1; //继续在R[mid+1..high]中查找
mid=(low+high)/2;
} //BinSeareh
if(R[mid]==K)return mid; //查找成功返回
else return -1; //当low>high时表示查找区间为空,查找失败
}
对我的回答有疑问可以Hi我!恭候!
易探云怎么样?易探云是国内一家云计算服务商家,致力香港服务器、国内外服务器租用及托管等互联网业务,目前主要地区为运作香港BGP、香港CN2、广东、北京、深圳等地区。目前,易探云推出深圳或北京地区的适合挂机和建站的云服务器,国内挂机宝云服务器(可选深圳或北京地区),独立ip;2核2G5M挂机云服务器仅330元/年起!点击进入:易探云官方网站地址易探云国内挂机宝云服务器推荐:1、国内入门型挂机云服务器...
bgpto怎么样?bgp.to日本机房、新加坡机房的独立服务器在搞特价促销,日本独立服务器低至6.5折优惠,新加坡独立服务器低至7.5折优惠,所有优惠都是循环的,终身不涨价。服务器不限制流量,支持升级带宽,免费支持Linux和Windows server中文版(还包括Windows 10). 特色:自动部署,无需人工干预,用户可以在后台自己重装系统、重启、关机等操作!bgpto主打日本(东京、大阪...
BGP.TO目前针对日本和新加坡服务器进行促销,其中日本东京服务器6.5折,而新加坡服务器7.5折起。这是一家专门的独立服务器租售网站,提供包括中国香港、日本、新加坡和洛杉矶的服务器租用业务,基本上都是自有硬件、IP资源等,国内优化直连线路,机器自动化部署上架,并提供产品的基本管理功能(自助开关机重启重装等)。新加坡服务器 $93.75/月CPU:E3-1230v3内存:16GB硬盘:480GB ...
二分法查找为你推荐
电视蚂蚁电视蚂蚁是不是不能用了?我在国外该怎样看奥运?qsv视频格式转换器手机qsv怎么转换成mp4格式转换器小蓝条我现在使用的是迅雷7、看空间的时候总会出现一个小蓝条写着下载,总是误点然后迅雷就弹出来了怎么解决?充值卡充值买完充值卡了,怎么充值好用的手机杀毒软件大家都在用什么手机杀毒软件?哪个最好用?微信收费微信提现收费是怎么计算的 从什么时候开始收费免杀远控求一款好使(免杀)远程控制软件?文件系统格式系统盘用什么格式好scanf字符串scanf输入字符串和gets输入字符串有什么区别cad2012序列号和密钥autocad 2012激活码
如何查询域名备案号 鲨鱼机 私人服务器 网站监控 阿里云代金券 mysql主机 上海域名 佛山高防服务器 hdd 东莞idc 外贸空间 德讯 双线空间 学生服务器 免费个人网页 网站加速 存储服务器 睿云 七十九刀 贵州电信 更多