Unity3d二分查找算法实现

作者: 好怕怕 | 来源:发表于2016-07-19 12:34 被阅读275次

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

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;
    }
}

相关文章

  • 分治算法(swift二分法排序递归实现)

    二分查找 1、二分查找(Binary Search) 2、二分查找的基本思想 swift算法实现

  • 算法之二分查找

    二分查找 二分查找是著名、高效并有应用广泛的查找算法。 二分常规实现 1.循环实现 下面我用python语言实现循...

  • 刷题笔记

    算法思想 一、二分查找 1. 算法思想 算法详解 算法细节 一定要看二分查找细节.md 实现时需要注意以下细节: ...

  • 算法之二分查找

    排序算法 二分查找 用于有序元素列表的查找性能: Python实现: C#实现

  • 算法-二分搜索算法

    算法:二分搜索算法(折半查找算法)时间复杂度: 二分搜索算法概述 二分搜索算法伪代码 二分搜索算法实现 二分搜索算...

  • 数据结构与算法之美笔记——二分查找(下)

    摘要: 基础的二分查找算法无论是概念还是实现都比较简单(关于 二分查找基础实现文章 可点击此处查看),但二分查找存...

  • 查找算法

    查找算法 1顺序查找 2二分查找 2.1二分查找思路分析 2.2代码实现 3插值查找 3.1插值查找原理介绍: ​...

  • 二分查找算法--Python语言描述

    当列表的数据是有序的情况下, 使用二分查找算法是非常高效的, 以下使用两种方式实现了二分查找。 二分查找的一般算法...

  • 数据结构和算法--二分查找

    二分查找 二分查找的思想 二分查找(Binary Search)算法,也叫折半查找算法。 二分查找针对的是一个有序...

  • 二分查找

    1.非顺序表查找最大值递归算法 2.顺序表的二分查找算法查找下标最小的特定元素x 递归实现 非递归实现

网友评论

    本文标题:Unity3d二分查找算法实现

    本文链接:https://www.haomeiwen.com/subject/lsmmjttx.html