二分法排序二分法插入排序的应用实例?

二分法排序  时间:2021-06-26  阅读:()

java 二分法排序

public class Lookup { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub /** * 二分法查找 */ int a[]={23,45,98,100,110,120,140}; int search=120;//记录要查找的元素 int lower=0;//记录第一个元素 int temp=a.length-1 ; int index=-1; while(lower<=temp){ index = (lower+temp)/2;//记录中间元素,用两边之和除2. int currentValue=a[index]; if(currentValue==search){//如果得到的数与要查找的数相等则break退出; break; }else if(currentValue<search){//如果得到的数要小于查找的数、就用下标加1;否则减一 lower=index+1; }else{ temp = index-1; } } if(lower<=temp){ System.out.println(search+"在数组中第:"+(index+1)+"位"); }else{ System.out.println("里面没有这个元素"); } } }

二分法查找的适用条件

说”二分查找法只适用于顺序存储的有序表“是正确的,说”指线性表中的元素按值非递减排列(即从小到大,但允许相邻元素值相等)“是为了程序的确定性。

实际上只要有序就可以。

按递减排序也可以用二分法。

只是必须把算法规则改变一下。

递增的算法:拿要查找数值与中间序号的数值比较若相等,查找成功;要查找数值比中间序号的数值大,在右边查找,低端序号改为原中间序号加1;要查找数值比中间序号的数值小,在左边查找,高端序号改为原中间序号减1;如此反复。

递减的算法:拿要查找数值与中间序号的数值比较若相等,查找成功;要查找数值比中间序号的数值大,在左边查找,高端序号改为原中间序号减1;要查找数值比中间序号的数值小,在右边查找,低端序号改为原中间序号加1;如此反复。

二分法比较次数

a500/2此,因为使用2分查找,所以从中间开始查找,假设从250开始找,首先比较250大于K还是小于K,如果大于则从250往后找至500 如果小于250,则往前找。

所以一分为2,那么最多也就是a500/2次了

二分法插入排序的复杂度分析

二分插入排序是稳定的与二分查找的复杂度相同; 最好的情况是当插入的位置刚好是二分位置 所用时间为O(n); 最坏的情况是当插入的位置不在二分位置 所需比较次数为 n S<=∑n「log?n「-2^n「log?n「+1 k= 1 平均时间O(n^2)

C语言中二分法和插入排序案例,就两个!只涉及数组与函数内容,主要是别涉及指针!

你好,二分法 #include #define f(x) (x*x*x-2*x*x+3*x-4) void main() { float a=-10,b=10,c,eps=1e-5; while ((b-a)>eps) { c=(a+b)/2; if(f(c)==0) break; else if(f(a)*f(c)<0) b=c; else a=c; } printf("root=%f ",c); } 插入排序 #include int main () { int n[10]; int i, j, k; int temp; for (i = 0; i <= 9; i++) { printf ("请输入第%d个数:", i + 1); scanf ("%d", &n[i]); } printf ("数组排序前效果如下 "); for (i = 0; i <= 9; i++) { printf ("%d ", n[i]); } printf (" "); for (i = 1; i <= 9; i++) { for (j = i - 1; j >= 0; j--) { if (n[j] < n[i]) break; } if (j != i - 1) { temp = n[i]; for (k = i; k >= j + 1; k--) n[k] = n[k - 1]; n[j + 1] = temp; } } printf ("数组排序后效果如下 "); for (i = 0; i <= 9; i++) { printf ("%d ", n[i]); } printf (" "); return 0; }

二分法插入排序的应用实例?

代码: #include void fun(int a[ ],int n) { int i,j,k,temp; for(i=0;i

HostKvm:夏季优惠,香港云地/韩国vps终身7折,线路好/机器稳/适合做站

hostkvm怎么样?hostkvm是一家国内老牌主机商家,商家主要销售KVM架构的VPS,目前有美国、日本、韩国、中国香港等地的服务,站长目前还持有他家香港CN2线路的套餐,已经用了一年多了,除了前段时间香港被整段攻击以外,一直非常稳定,是做站的不二选择,目前商家针对香港云地和韩国机房的套餐进行7折优惠,其他套餐为8折,商家支持paypal和支付宝付款。点击进入:hostkvm官方网站地址hos...

咖啡主机22元/月起,美国洛杉矶弹性轻量云主机仅13元/月起,高防云20G防御仅18元/月

咖啡主机怎么样?咖啡主机是一家国人主机销售商,成立于2016年8月,之前云服务器网已经多次分享过他家的云服务器产品了,商家主要销售香港、洛杉矶等地的VPS产品,Cera机房 三网直连去程 回程CUVIP优化 本产品并非原生地区本土IP,线路方面都有CN2直连国内,机器比较稳定。咖啡主机目前推出美国洛杉矶弹性轻量云主机仅13元/月起,高防云20G防御仅18元/月;香港弹性云服务器,香港HKBN CN...

DogYun香港BGP月付14.4元主机简单测试

前些天赵容分享过DogYun(狗云)香港BGP线路AMD 5950X经典低价云服务器的信息(点击查看),刚好账户还有点余额够开个最低配,所以手贱尝试下,这些贴上简单测试信息,方便大家参考。官方网站:www.dogyun.com主机配置我搞的是最低款优惠后14.4元/月的,配置单核,512MB内存,10GB硬盘,300GB/50Mbps月流量。基本信息DogYun的VPS主机管理集成在会员中心,包括...

二分法排序为你推荐
短信营销方案短信营销怎么才能更有效果呢?网络视频下载器谁能给我找个网络视频下载器和转换器?renderpartialrender farm 是什么意思listviewitem怎么获取ListView里Item中的控件pat是什么格式如何把JPG图片变为PAT格式图片?averagesPoisson-Arrivals-See-Time-Averages是什么意思云输入法QQ云输入法怎样进行中英文切换?网络安全密钥网络安全密钥和wifi密码有什么区别sms是什么什么是SMS协议怎么查微信注册时间怎么知道微信上次登录时间
vps安全设置 冰山互联 国外服务器 css样式大全 免费博客空间 发包服务器 老左正传 国外代理服务器地址 吉林铁通 独立主机 lamp兄弟连 国外免费网盘 美国主机侦探 美国asp空间 优惠服务器 在线tracert paypal兑换 ddos攻击器 六维空间登陆首页 ibm服务器机柜 更多