韩漫免费漫画在线观看方法,《好好疼爱里面》免费看,年轻漂亮的女士护士内衣,妈妈醉酒后把我当爸爸电视剧

文章 > java基础 > java二分查找如何实现迭代

java二分查找如何实现迭代

头像

小妮浅浅

2021-01-29 11:58:422710浏览 · 0收藏 · 0评论

我们对于某些命令的重复操作,会用到迭代的思想。而在迭代的过程中,跟数组也有着密不可分的联系。本篇以java中的二分查找为例,找寻在其中实现迭代的方法。当然在此之前,我们需要对迭代的基础内容有所了解,然后在结合二分查找一起进行实例探索,下面一起来看详细的内容。

1.迭代概念

对一组指令或一定步骤进行重复执行称为迭代(iterator)。通俗点说,叫一个个数过去。

实现这样一个个数过去功能的东西,叫迭代器。

2.迭代三要素

1.确定变量

在可以用迭代算法解决的问题中,至少存在一个直接或间接地不断由旧值递推出新值的变量,这个变量就是迭代变量。

2.建立关系式

所谓迭代关系式,指如何从变量的前一个值推出其下一个值的公式(或关系)。迭代关系式的建立是解决迭代问题的关键,通常可以使用递推或倒推的方法来完成。

3.过程控制

在什么时候结束迭代过程?这是编写迭代程序必须考虑的问题。不能让迭代过程无休止地重复执行下去。迭代过程的控制通常可分为两种情况:一种是所需的迭代次数是个确定的值,可以计算出来;另一种是所需的迭代次数无法确定。对于前一种情况,可以构建一个固定次数的循环来实现对迭代过程的控制;对于后一种情况,需要进一步分析出用来结束迭代过程的条件。

3.二分查找的迭代实例

/*非递归的折半查找*/
public static int binarySearch(int[] a, int x) {
int left = 0;
int right = a.length - 1;
while(left <= right) {
int mid = (left+ right) / 2;
if(x > a[mid]) {
left = mid+1;
} else if(x < a[mid]) {
right = mid-1;
} else {
return mid;
}
}
return -1;
}

每次迭代在循环内的所有工作话费O(1),因此分析需要确定循环的次数。循环从right-left=leng-1开始并在right-left<= -1结束。每次循环后right-left的值至少将该循环前的值折半;于是,循环的次数最多是[log(n-1)]+2。因此:运行的时间是O(log N),而递归的时间复杂度则需要O(N)。

以上就是java二分查找实现迭代的方法,建议大家对迭代和二分查找的基础知识点掌握牢固后,在进行二者的结合使用。有概念模糊的地方,可以在课后查找有关资料。

关注

关注公众号,随时随地在线学习

本教程部分素材来源于网络,版权问题联系站长!

空姐少女正版2| 妈妈的职业4免费观看全集在线播..| 初中小姐姐脚丫踩在男生困困| 《一滴都不许漏》何泽城林荫| 男人吸吮完乳房应该怎么处理 | 《熟睡的女邻居HD| 真人版结婚之夜女性教育PPT| 《厨房激战5》完整版在线观看| 瑜伽裤透明全毛露丁字裤| 男生把困困放在女生定眼| 日本《暴力强伦轩》| 《慈母夜吟》完整版| 《从上司到妻子》动画结局 | 啵啵影院| 爱动漫网| 淑芬两腿间又痒又疼的原因| 妈妈出轨了免费观看电视剧全集| 扌吴辽鬲还是扌暴辽鬲小说| 《与上司做爰HD》| 父女一起到达巅峰的小说| 欧美大片PPT免费大全| 《妻欲公与媳》免费看| 苍井空| 《请好好疼爱里面》免费观看| 河莉秀电影| 浅仓彩音| 十大名阴排名一览表| 共享女儿小诗1~10章的背景资..| 男人女人免费观看40集电视剧| 无法抗拒的你ID中字| 初中小姐姐脚丫踩在男生困困| 屁股翘起来跪在床上有好处吗| 欲奴性猛交2无删减| 《少妇交换做爰6| 《厨房激战5》完整版在线观看| 小婕子太紧了太深了| 美女和帅哥一起努力生产豆浆的视频 | 妈妈的秘密| 摸摸大扔子的视频大全| 风起云涌之情迷香江| 白色变态蕾丝超薄开档连身袜