C# 二分查找

本文详细介绍了二分查找算法的工作原理,包括其在有序数组中的高效搜索过程,并给出了C#中的示例代码,包括数值和字符串数组的查找。

        二分查找(Binary Search)是一种在有序数组或列表中查找特定元素的搜索算法。该算法比较要搜索的值和数组的中间元素。如果要搜索的值小于中间元素,则在数组的左半部分继续搜索;如果要搜索的值大于中间元素,则在数组的右半部分继续搜索。不断重复这个过程,直到找到要搜索的值或确定搜索范围为空为止。

        二分查找是一种高效的查找算法,因为在每次比较后,搜索范围可以减半,时间复杂度为O(log n)。二分查找的前提是数组或列表中元素已按照某种顺序(通常是升序)排列。

具体步骤如下:

  1. 初始化左指针left和右指针right,分别指向数组的起始和结束位置。
  2. 不断计算中间位置mid,即mid = (left + right) / 2。
  3. 比较要搜索的值与数组中间元素array[mid]的大小。
  4. 如果要搜索的值等于array[mid],则找到目标,返回mid。
  5. 如果要搜索的值小于array[mid],则更新右指针right = mid - 1。
  6. 如果要搜索的值大于array[mid],则更新左指针left = mid + 1。
  7. 重复上述过程,直到找到目标或确定搜索范围为空。

如果数组或列表不是有序的,可以先对其进行排序,然后再利用二分查找进行搜索。

C#中实现二分查找的完整示例代码:

using System;

class BinarySearchExample
{
    static int BinarySearch(int[] array, int target)
    {
        int left = 0;
        int right = array.Length - 1;

        while (left <= right)
        {
            int mid = left + (right - left) / 2;

            if (array[mid] == target)
            {
                return mid;
            }
            else if (array[mid] < target)
            {
                left = mid + 1;
            }
            else
            {
                right = mid - 1;
            }
        }

        return -1; // Target not found in the array
    }

    static void Main()
    {
        int[] array = { 1, 3, 5, 7, 9, 11, 13, 15, 17 };
        int target = 9;

        int result = BinarySearch(array, target);

        if (result != -1)
        {
            Console.WriteLine($"Target {target} found at index {result}");
        }
        else
        {
            Console.WriteLine("Target not found in the array");
        }
    }
}

这个示例代码实现了一个对有序数组进行二分查找的功能。你可以根据需要修改数组和目标值以进行测试。

示例二 查找字符串:

        在C#中,二分查找通常是用于在有序数组中查找数值类型的数据,而不是用于在字符串数组中查找字符串。不过,如果你需要在有序的字符串数组中查找特定的字符串,你可以按照以下步骤创建一个二分查找的示例代码:

using System;

class StringBinarySearchExample
{
    static int StringBinarySearch(string[] array, string target)
    {
        int left = 0;
        int right = array.Length - 1;

        while (left <= right)
        {
            int mid = left + (right - left) / 2;

            int compareResult = String.Compare(array[mid], target);

            if (compareResult == 0)
            {
                return mid;
            }
            else if (compareResult < 0)
            {
                left = mid + 1;
            }
            else
            {
                right = mid - 1;
            }
        }

        return -1; // Target not found in the array
    }

    static void Main()
    {
        string[] array = { "apple", "banana", "orange", "strawberry", "watermelon" };
        string target = "orange";

        int result = StringBinarySearch(array, target);

        if (result != -1)
        {
            Console.WriteLine($"Target {target} found at index {result}");
        }
        else
        {
            Console.WriteLine("Target not found in the array");
        }
    }
}

        在上面示例代码中,修改了二分查找算法,使其可以在有序的字符串数组中查找特定的字符串。你可以根据需要修改字符串数组和目标字符串以进行测试。

C#中的二分查找是一种高效的查找算法,它适用于已排序的数组或列表。下面是使用C#实现二分查找的步骤: 1. 确保数组或列表已排序。如果未排序,需要先对其进行排序。 2. 定义一个方法来执行二分查找。该方法接收三个参数:要查找的目标值、要查找的数组或列表、以及数组或列表的起始和结束索引。 3. 在方法内部,计算数组或列表的中间索引:(start + end) / 2。 4. 比较目标值与中间元素的值。如果相等,则返回中间索引。 5. 如果目标值小于中间元素的值,则在左半部分继续进行二分查找。更新结束索引为中间索引减1,并递归调用二分查找方法。 6. 如果目标值大于中间元素的值,则在右半部分继续进行二分查找。更新起始索引为中间索引加1,并递归调用二分查找方法。 7. 如果起始索引大于结束索引,则表示目标值不存在于数组或列表中,返回-1。 下面是一个示例代码: ```csharp public static int BinarySearch(int target, int[] array, int start, int end) { if (start > end) return -1; int mid = (start + end) / 2; if (array[mid] == target) return mid; else if (array[mid] > target) return BinarySearch(target, array, start, mid - 1); else return BinarySearch(target, array, mid + 1, end); } ``` 使用示例: ```csharp int[] array = { 1, 3, 5, 7, 9 }; int target = 5; int result = BinarySearch(target, array, 0, array.Length - 1); if (result != -1) Console.WriteLine("目标值在数组中的索引为:" + result); else Console.WriteLine("目标值不存在于数组中。"); ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

hefeng_aspnet

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值