Unity3d二分查找算法实现

简介: 二分查找又称折半查找,优点是比较次数少,查找速度快,平均性能好;其缺点是要求待查表为有序表,且插入删除困难。因此,折半查找方法适用于不经常变动而查找频繁的有序列表。

二分查找又称折半查找,优点是比较次数少,查找速度快,平均性能好;其缺点是要求待查表为有序表,且插入删除困难。因此,折半查找方法适用于不经常变动而查找频繁的有序列表。首先,假设表中元素是按升序排列,将表中间位置记录的关键字与查找关键字比较,如果两者相等,则查找成功;否则利用中间位置记录将表分成前、后两个子表,如果中间位置记录的关键字大于查找关键字,则进一步查找前一子表,否则进一步查找后一子表。重复以上过程,直到找到满足条件的记录,使查找成功,或直到子表不存在为止,此时查找不成功。
开始我们的代码

using UnityEngine;

/// <summary>
/// 二分查找算法(在有序数组中快速寻找一个指定数值)
/// </summary>
public class BinarySearchSort : MonoBehaviour
{
    //有序数组
    int[] array = new[] {5, 6, 7, 8, 9, 12, 45, 55};

    void Start()
    {
        //调用查找方法,输出 bool值
        Debug.Log(BinarySearch(array, 45));
    }

    /// <summary>
    /// 二分查找方法
    /// </summary>
    /// <param name="array">数组</param>
    /// <param name="targetNum">目标数值</param>
    /// <returns>是否找到目标数值</returns>
    bool BinarySearch(int[] array, int targetNum)
    {
        //起始点
        int start = 0;
        //结束点
        int end = array.Length - 1;
        //中界点
        int mid;

        //循环遍历(起始点<=终止点)
        while (start <= end)
        {
            //计算中界点
            mid = (start + end)/2;
            //第一种情况
            if (array[mid] > targetNum)
            {
                //终止点=中界点-1
                end = mid - 1;
            }
            //第二种情况
            else if (array[mid] < targetNum)
            {
                //起始点=中界点+1
                start = mid + 1;
            }
            //找到
            else
            {
                Debug.Log("所在下标:" + mid);
                return true;
            }
        }
        //未找到
        Debug.Log("不存在该数值!");
        return false;
    }
}
相关文章
|
3月前
|
算法 测试技术 索引
算法-二分查找
算法-二分查找
32 0
|
6天前
|
算法
【算法】二分查找——二分查找
【算法】二分查找——二分查找
|
6天前
|
算法
【算法】二分查找——在排序数组中查找元素的第一个和最后一个位置
【算法】二分查找——在排序数组中查找元素的第一个和最后一个位置
|
4天前
|
存储 算法 Java
深入算法基础二分查找数组
文章深入学习了二分查找算法的基础,通过实战例子详细解释了算法的逻辑流程,强调了确定合法搜索边界的重要性,并提供了Java语言的代码实现。
深入算法基础二分查找数组
|
1月前
|
算法
【算法】二分查找(整数二分和浮点数二分)
算法学习——二分查找(整数二分和浮点数二分)
25 0
【算法】二分查找(整数二分和浮点数二分)
|
2月前
|
存储 算法 C语言
二分查找算法的概念、原理、效率以及使用C语言循环和数组的简单实现
二分查找算法的概念、原理、效率以及使用C语言循环和数组的简单实现
|
2月前
|
机器学习/深度学习 算法 索引
数据结构算法--1 顺序查找二分查找
**顺序查找时间复杂度为O(n)**,适合无序列表,可以通过`enumerate`或直接遍历索引来实现。**二分查找时间复杂度为O(logn)**,适用于有序列表,利用Python中`left`、`right`指针和`mid`点不断缩小搜索范围。效率上二分查找更优。
|
2月前
|
存储 算法 Java
Java查找算法概览:二分查找适用于有序数组,通过比较中间元素缩小搜索范围;哈希查找利用哈希函数快速定位,示例中使用HashMap存储键值对,支持多值关联。
【6月更文挑战第21天】Java查找算法概览:二分查找适用于有序数组,通过比较中间元素缩小搜索范围;哈希查找利用哈希函数快速定位,示例中使用HashMap存储键值对,支持多值关联。简单哈希表实现未涵盖冲突解决和删除操作。
28 1
|
2月前
|
算法 搜索推荐 Java
二分查找算法详解及实现
二分查找算法详解及实现
36 2
|
1月前
|
算法 JavaScript
JS 【算法】二分查找
JS 【算法】二分查找
20 0