码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Java关于普通查找和二分查找


    /**
     * 普通查找就是一个接一个地找(逐个找),对于数组是否已经排序没有要求
     */
    public class 普通查找 {
        public static void main(String[] args) {
    //        静态初始化一个int数组
            int[] array = {6,9,2,5,3,8,7};
    //        采用逐个查找方法,查找元素8
            for (int i = 0; i < array.length-1; i++) {
                if (array[i] == 8){
                    System.out.println("查找的元素的下标是:" + i);
                    return;
                }
            }
            System.out.println("在该数组中没有此元素!");
        }
    }
    /**
     * 关于二分法查找是建立在排序基础之上的,二分法查找在java.util.Arrays下面已经写好
     * 方法名为"binarySearch",我们这里只是分析其原理。
     */
    public class 二分法查找 {
        public static void main(String[] args) {
    //        静态初始化一个int数组
            int[] array = {2,9,21,55,93,98,117};
    //        查找
            int index = erFenFaChaZhao(array,117);
            System.out.println(index == -1? "没有找到该元素!":"该元素的下标是:" + index);
    
        }
    
        /**
         * 查找数组中的元素
         * @param array 被查找的数组
         * @param ele 被查找的元素
         * @return -1表示没有找到该元素,大于等于0表示被查找元素的下标
         */
    
        public static int erFenFaChaZhao(int[] array, int ele) {
            //最初开始元素下标
            int begin = 0;
            //最初结束元素下标
            int end = array.length-1;
            //在循环体中begin一直在增加,end一直在减少,只要begin <= end就一直循环
            while (begin <= end){
                //通过开始元素下标和结束元素下标获取中间元素下标
                int mid = (begin + end) / 2;
                //如果中间下标对应的元素正好等于被查找的元素,就返回该下标,并结束方法
                if (array[mid] == ele){
                    return mid;
                //如果中间下标对应的元素小于被查找的元素,说明被查找的元素在中间元素的右侧
                }else if (array[mid] < ele){
                    //重新定位新的开始元素下标
                    begin = mid + 1;
                //程序运行到此说明中间元素下标对应的元素大于被查找的元素,说明被查找的元素在中间元素的左侧
                }else {
                    //重新定位结束元素的下标
                    end = mid - 1;
                }
            }
            return -1;
        }
    }
  • 相关阅读:
    Zookeeper的介绍与集群搭建
    分享几个简单实用的 JavaScript 优雅小技巧!
    张益唐的朗道-西格尔零点猜想的论文公布,专家认为该论文尚未完整解决零点猜想
    LeetCode --- 2068. Check Whether Two Strings are Almost Equivalent 解题报告
    【python数据分析刷题】-N04.中级函数
    PDF格式分析(七十九)——图章、墨迹注释(Stamp、Ink)
    嵌入式系统,ARM微处理器特点,ARM体系结构,特征、状态、操作模式等,中断分类,JTAG调试接口
    基于YOLOv5的手势识别系统(含手势识别数据集+训练代码)
    矩阵的投影、线性拟合与最小二乘法
    Git常见命令总结
  • 原文地址:https://blog.csdn.net/heliuerya/article/details/128213656
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号