Java——折半查找

本文深入探讨了折半查找算法,又称二分查找,适用于有序的顺序表。介绍了其基本思路,通过不断缩小查找范围来提高效率,最终实现快速定位。提供了C和Java两种语言的实现代码,并分析了其时间复杂度为O(log2n)。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

折半查找:
又称二分查找,仅适用于有序的顺序表。
基本思路为:首先将给定值key与表中中间位置元素的关键字比较,若相等,则查找成功,返回元素位置,若不等,则所需查找的元素只能在中间元素以外的前半部分或后半部分中(例如:若升序表中,给定的key大于中间元素的关键字,则所查找的元素只可能在后半部分)。然后缩小范围继续进行同样的查找,如此重复,直至找到为止,或者查找失败!

经典算法:

int Binary_Search(SeqList L, ElemType key){
    int low=0,mid;
    int high=L.Table_len-1;
    while(low<=high)
    {
        mid=(low+high)/2;//取中间位置
        if(L.elem[mid==key])
        	return mid;//查找成功返回所在位置
        else if(L.elem[mid]>key)
        	high=mid-1;//关键字比中间值小,从前半部分查找
        else 
        	low=mid+1;//关键字比中间值大,从后半部分查找
    }
    return -1;
}

时间复杂度为:O(log2n)

Java编写折半查找:

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Scanner;

public class 折半查找 {//输入序列为有序的数列

	static Scanner get=new Scanner(System.in);
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		
		ArrayList<Integer> arr_list=new ArrayList<>();
		array_cin(arr_list);
		
		int arr_change[]=new int[arr_list.size()];
		change(arr_list, arr_change);
		
		System.out.println("请输入待查找的数:");
		get.reset();
		int key=get.nextInt();
		
		get.close();
		System.out.println("位置为:"+Binary_Search(arr_change, key));
	}
	static int Binary_Search(int arr[], int key) {//折半查找(二分查找)算法
		int low=0;
		int high=arr.length-1;
		int mid;
		while(low<=high) {
			mid=(low+high)/2;
			if(arr[mid]==key) {
				return mid+1;
			}else if(arr[mid]>key){
				high=mid-1;
			}else {
				low=mid+1;
			}
		}		
		return -1;
	}
	
	static void change(ArrayList<Integer> arr_list,int arr[]) {//转换动态数组为有序普通数组,两个数组长度一致
		for(int i=0;i<arr_list.size();i++) {
			arr[i]=arr_list.get(i);
		}
		Arrays.sort(arr);
	}
	
	static void array_cin(ArrayList<Integer> list) {//实现动态输入一系列数字
		System.out.println("请输入一系列目标数:");
		String str=get.nextLine();//最后输入后,游标会移至下一位开头
        String[] srr=str.split(" ");
        for (int i = 0; i < srr.length; i++) {
            list.add(Integer.valueOf(srr[i]));
        }
	}

}

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

九思梦鹿

喜欢,请记得点赞或赞赏哟

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值