【内功】基础算法——二分查找
1. 自己实现 lower_bound, upper_bound
1 int my_lower_bound(vector<int> nums, int target) { 2 int left = 0, right = nums.size(); 3 while (left < right) { 4 long long mid = left + (right - left) / 2; 5 if ((nums[mid] < target) { 6 left = mid + 1; 7 } else { 8 right = mid; 9 } 10 } 11 return left; 12 }
1 int my_upper_bound(vector<int> nums, int target) { 2 int left = 0, right = nums.size(); 3 while (left < right) { 4 long long mid = left + (right - left) / 2; 5 if ((nums[mid] > target) { 6 right = mid; 7 } else { 8 left = mid + 1; 9 } 10 } 11 return left; 12 }
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步