Java的数组查找

在java中,我们常用的查找有两种:

1.顺序查找 SeqSearch.java

2.二分查找(这里只提供思路)

案例:有一个数列:白眉鹰王,金毛狮王,紫衫龙王,青翼蝠王 猜数游戏:从键盘中任意输入一个名称,判断数列中是否包含此名称[顺序查找]要求:如果找到,就提示找到,并且给出下标值

(下面我自己写的,后来感觉这方法很笨)

java 复制代码
import java.util.Scanner;
public class arraySearch{
    public static void main(String args[]){
        //有一个数列:白眉鹰王,金毛狮王,紫衫龙王,青翼蝠王 猜数游戏:从键盘中任意输入一个名称,判断数列中是否包含此名称[顺序查找]要求:如果找到,就提示找到,并且给出下标值
        String wordarr[] = {"白眉鹰王","金毛狮王","紫衫龙王","青翼蝠王"};
        Scanner myScanner = new Scanner(System.in);
        System.out.println("请输入要猜的名称");
        String key = myScanner.next();
        switch(key){
            case("白眉鹰王"): {
                for (int i = 0; i < wordarr.length; i++) {
                    if (wordarr[i].equals(key)) {
                        System.out.println(key + " 的下标是: " + i);
                        break;
                    }
                }
            }
            break;
            case("金毛狮王"): {
                for (int i = 0; i < wordarr.length; i++) {
                    if (wordarr[i].equals(key)) {
                        System.out.println(key + " 的下标是: " + i);
                        break;
                    }
                }
            }
            break;
            case("紫衫龙王"): {
                for (int i = 0; i < wordarr.length; i++) {
                    if (wordarr[i].equals(key)) {
                        System.out.println(key + " 的下标是: " + i);
                        break;
                    }
                }
            }
            break;
            case("青翼蝠王"): {
                for (int i = 0; i < wordarr.length; i++) {
                    if (wordarr[i].equals(key)) {
                        System.out.println(key + " 的下标是: " + i);
                        break;
                    }
                }
            }
            break;
            default:
                System.out.println("输入有误,程序退出");
        }


    }
}

更聪明的方法:

java 复制代码
import java.util.Scanner;
public class SeqSearch {
    public static void main(String args[]) {
        //有一个数列:白眉鹰王,金毛狮王,紫衫龙王,青翼蝠王 猜数游戏:从键盘中任意输入一个名称,判断数列中是否包含此名称[顺序查找]要求:如果找到,就提示找到,并且给出下标值
        String names[] = {"白眉鹰王", "金毛狮王", "紫衫龙王", "青翼蝠王"};
        int index = -1;//定义一个索引变量,如果下面的if语句执行成功,则index不再等于-1,就不会弹出"没找到"
        Scanner myScanner = new Scanner(System.in);
        System.out.println("请输入名称");
        String findName = myScanner.next();
        for(int i = 0;i < names.length;i++)
        {
            //比较字符串equals
            if(findName.equals(names[i]))
            {
                System.out.println("找到了,下标值是" + i);
                index = i;//如果找到了数组中相等的语句就改变index的值,使其不会弹出"没找到"
                break;
            }
        }
        if(index == -1)
            System.out.println("没找到");





    }
}

二分查找(仅提供思想不提供代码):

请对一个有序数组进行二分查找{1,8,10,89,1000,1234},输入一个数看看该数组是否存在此数,并且求出下标,如果没有就提示"没有这个数"

首先,二分查找要求提供的数组是有序的,以上面的数组为例,首先会将输入的数字与数组中间的数比对,如果输入的数大于中间的数则往它右边继续查找,反之则往左边查找

相关推荐
ytttr87310 小时前
64QAM信号的数字预失真处理(MATLAB实现)
开发语言·matlab
Nebula_g10 小时前
C语言应用实例:硕鼠游戏,田忌赛马,搬桌子,活动选择(贪心算法)
c语言·开发语言·学习·算法·游戏·贪心算法·初学者
爱吃甜品的糯米团子11 小时前
详解 JavaScript 内置对象与包装类型:方法、案例与实战
java·开发语言·javascript
郝学胜-神的一滴11 小时前
Linux下,获取子进程退出值和异常终止信号
linux·服务器·开发语言·c++·程序人生
程序定小飞11 小时前
基于springboot的学院班级回忆录的设计与实现
java·vue.js·spring boot·后端·spring
AI科技星11 小时前
张祥前统一场论动量公式P=m(C-V)误解解答
开发语言·数据结构·人工智能·经验分享·python·线性代数·算法
攀小黑11 小时前
基于若依-内容管理动态修改,通过路由字典配置动态管理
java·vue.js·spring boot·前端框架·ruoyi
CodeByV11 小时前
【C++】继承
开发语言·c++
青云交12 小时前
Java 大视界 -- 基于 Java 的大数据可视化在城市空气质量监测与污染溯源中的应用
java·spark·lstm·可视化·java 大数据·空气质量监测·污染溯源
权泽谦12 小时前
用 Python 做一个天气预报桌面小程序(附源码 + 打包与部署指导)
开发语言·python·小程序