志,敢教日月换新天。为有牺牲多壮

[Swift]二分法的两种方式

★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公众号:山青咏芝(shanqingyongzhi)
➤博客园地址:山青咏芝(https://www.cnblogs.com/strengthen/ 
➤GitHub地址:https://github.com/strengthen/LeetCode
➤原文地址:https://www.cnblogs.com/strengthen/p/10403410.html 
➤如果链接不是山青咏芝的博客园地址,则可能是爬取作者的文章。
➤原文已修改更新!强烈建议点击原文地址阅读!支持作者!支持原创!
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★

热烈欢迎,请直接点击!!!

进入博主App Store主页,下载使用各个作品!!!

注:博主将坚持每月上线一个新app!!!

扩展数组:

复制代码
 1 extension Array
 2 {    
 3     //二分法方式1
 4     func binarySearch(_ nums:[Int],_ target: Int) -> Int
 5     {
 6         var low = 0
 7         var high = nums.count - 1
 8         var mid = (low + high) >> 1
 9         
10         while low <= high {
11             let val = nums[mid]
12             if target == val {
13                 return mid
14             } else if target < val {
15                 high = mid - 1
16             } else {
17                 low = mid + 1 
18             }
19             mid = (low + high) >> 1
20         }
21         return high
22     }
23     
24     //二分法方式2
25     func binarySearch(_ nums:[Int],_ start: Int, _ end: Int,_ target: Int) -> Int
26     {
27         let mid = start + (end - start) / 2
28         if nums[mid] >= target && (start == mid || nums[mid - 1] < target) 
29         { 
30             return mid 
31         }
32         if nums[mid] < target 
33         {
34             return binarySearch(nums,target, mid + 1, end)
35         }
36         return binarySearch(nums,target, start, mid - 1)
37     }
38 }
复制代码

测试代码:

复制代码
 1 //注:不含有元素5
 2 var arr = [1,2,3,4,6,7,8,9]
 3 print(arr.binarySearch(arr,5))
 4 //Print 3
 5 print(arr.binarySearch(arr,0,arr.count,5))
 6 //Print 4
 7 
 8 //注:含有元素6
 9 print(arr.binarySearch(arr,6))
10 //Print 4
11 print(arr.binarySearch(arr,0,arr.count,6))
12 //Print 4
复制代码

 

posted @   为敢技术  阅读(301)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示
哥伦布
09:09发布
哥伦布
09:09发布
2°
西南风
2级
空气质量
相对湿度
62%
今天
2°/16°
周二
7°/19°
周三
多云
7°/19°