java 算法二分查找和折半查找

2025-05-29 0 29

java 算法二分查找折半查找

折半查找 :首先数组是已经排好序的

实例代码:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60
package com.hao.myrxjava;

/**

* 折半查找 :首先数组是已经排好序的

*

* @author zhanghaohao

* @date 2017/5/15

*/

public class HalfDivision {

/**

* 循环实现

*

* @param array 排好序的数组

* @param value 查找的值

* @return value在array的位置

*/

public static int halfDivision(int value, int[] array) {

if (array == null || array.length == 0)

throw new NullPointerException("array is null");

int low = 0;

int high = array.length - 1;

int mid = (low+high)/2;

while (array[mid] != value) {

if (array[mid] > value)

high = mid - 1;

else

low = mid + 1;

if (low > high)

return -1;

mid = (low+high)/2;

if (array[mid] == value)

return mid;

}

return mid;

}

/**

* 递归实现

*

* @param array 排好序的数组

* @param value 查找的值

* @param low 查找的起始位置

* @param high 查找的末尾位置

* @return value在array的位置

*/

public static int halfDivision(int value, int[] array, int low, int high) {

if (low > high)

return -1;

int mid = (low + high) / 2;

if (array[mid] == value)

return mid;

else if (array[mid] > value)

return halfDivision(value, array, low, mid - 1);

else if (array[mid] < value)

return halfDivision(value, array, mid+1, high);

return -1;

}

}

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

原文链接:http://blog.csdn.net/android_text/article/details/72146398

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 java 算法二分查找和折半查找 https://www.kuaiidc.com/116642.html

相关文章

发表评论
暂无评论