Java算法03-查找

一、线性查找

1.基本思想:

从左到右挨个查找

2.特点:

查找效率慢

3.代码:

import java.util.Scanner;

/**
 * @author: TSCCG
 * @date: 2021/5/10
 */
public class Search {
    /**
     * 1.线性查找
     * 查询速度慢
     */
    public static void linearSearch(String[] arr, String dest1) {
        boolean isFlag1 = true; // 处理查询不到时的情况
        for(int i = 0;i < arr.length;i++) {
            if(dest1.equals(arr[i])) {
                System.out.println("查询成功!该元素在数组中的位置是:" + (i + 1));
                isFlag1 = false; // 如果找到目标元素,就将isFlag1赋值为false
            }
        }
        if(isFlag1) { // 如果未找到目标元素,那么isFlag1的值将仍为true,执行下列语句
            System.out.println("查询失败!");
        }
    }
      /**
     * 程序入口
     */
    public static void main(String[] args) {
//        Scanner sc =  new Scanner(System.in);
//        String dest1 = sc.next();
        String[] arr1 = {"AA","BB","CC","DD"};
        String dest1 = "CC";
        linearSearch(arr1,dest1);
        String dest2 = "WC";
        linearSearch(arr1,dest2);
    }
}

结果:

查询成功!该元素在数组中的位置是:3
查询失败!

二、二分查找

1.基本思想:

  1. 先找到数组中间的元素,判断与目标元素的关系:

  2. 若就是要查找的元素则输出查找成功

  3. 若大于要查找的数则继续对左半边的元素执行步骤1

  4. 若小于则继续对右半边的元素执行步骤1

  5. 重复以上步骤,直到找到目标元素

2.特点:

数组必须要有序且是顺序储存的,一般要用到排序算法(详见:https://www.cnblogs.com/TSCCG/p/14748591.html)

效率快,尤其当数据量大时

3.代码:

/**
 * @author: TSCCG
 * @date: 2021/5/10
 */
public class Search {
    /**
     * 2.二分查找
     * 查询速度快
     * 数组必须是有序的
     */
    public static void binarySearch(int[] arr,int dest2) {
        int head = 0;
        int end = arr.length - 1;
        boolean isFlag2 = true;
        while(head <= end) {
            int middle = (head + end) / 2;
            if(dest2 == arr[middle]) {
                System.out.println("查找成功,该元素在数组中的位置是:" + (middle + 1));
                isFlag2 = false;
                break;
            } else if(dest2 > arr[middle]) {
                // 走到这步时说明本次的arr[middle]不是目标元素,
                // 那么就可以将此元素排除出下次的查询范围,故head = middle + 1
                head = middle + 1;
            } else { //dest2 < arr[middle]
                end = middle - 1;
            }
        }
        if(isFlag2) {
            System.out.println("查询失败!");
        }
    }
    /**
     * 程序入口
     */
    public static void main(String[] args) {
        int[] arr2 = {-3,0,12,34,55,102};
        int dest3 = -3;
        binarySearch(arr2,dest3);
        int dest4 = 996;
        binarySearch(arr2,dest4);
    }
}

结果:

查找成功,该元素在数组中的位置是:1
查询失败!
posted @ 2021-05-10 15:55  TSCCG  阅读(70)  评论(0编辑  收藏  举报