C++实现查找最接近目标值的数字及开发建议
### 🔍 思路分析 本题可以使用二分查找来解决。二分查找的基本思想是将数组分成两部分,根据中间元素与目标值的大小关系,缩小查找范围,直到找到最接近目标值的元素。 ### 💻 代码实现 ```cpp #include <iostream> #include <vector> #include <cmath> using namespace std; // 找到最接近目标值 k 的数字 int findClosest(vector<int>& nums, int k) { int left = 0, right = nums.size() - 1; while (left < right) { int mid = left + (right - left) / 2; if (nums[mid] < k) { left = mid + 1; } else { right = mid; } } // 比较 left 和 left - 1 哪个更接近 k if (left > 0 && abs(nums[left - 1] - k) <= abs(nums[left] - k)) { return nums[left - 1]; } return nums[left]; } int main() { int n; cin >> n; vector<int> nums(n); for (int i = 0; i < n; ++i) { cin >> nums[i]; } int k; cin >> k; int result = findClosest(nums, k); cout << result << endl; return 0; } ``` ### 📝 代码解释 1. **二分查找**:在 `findClosest` 函数中,使用二分查找找到第一个大于等于目标值 `k` 的元素的位置。 2. **比较**:找到位置后,比较该位置和其前一个位置的元素哪个更接近目标值 `k`,如果前一个位置的元素更接近或者距离相同,则返回前一个位置的元素,否则返回当前位置的元素。 ### ⚙️ 复杂度分析 - **时间复杂度**:$O(log n)$,其中 $n$ 是数组的长度。二分查找的时间复杂度是 $O(log n)$。 - **空间复杂度**:$O(1)$,只使用了常数级的额外空间。 ### 💡 开发建议 - **边界条件处理**:在处理二分查找时,要注意边界条件,如数组为空、目标值小于数组第一个元素或大于数组最后一个元素等情况。 - **代码可读性**:可以添加一些注释来提高代码的可读性,特别是在二分查找的关键步骤。 - **错误处理**:在实际应用中,可以添加一些错误处理代码,如输入的数组是否为空等。 ### 📚 学习资源 - [C++ 官方文档](https://en.cppreference.com/w/) - 《C++ Primer》 ######[AI写代码神器 | 663点数解答 | 2026-06-05 19:57:23]
- C++ 实现:精准统计给定范围 [L, R] 内数字 2 出现的次数及代码详解(字节豆包 | 401点数解答 | 2026-02-05 21:17:05)80
- C++实现:统计[L, R]范围内数字2出现的次数及代码详解(字节豆包 | 489点数解答 | 2026-02-07 17:12:26)96
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)408
- C++二分查找实战:在有序数组中寻找最接近目标值的数字(DeepSeek | 1612点数解答 | 2026-03-15 18:48:06)19
- C++实现查找排序数组中最接近目标值的数字(字节豆包 | 710点数解答 | 2026-04-26 13:10:10)19
- Python:用正则表达式从含多种字符的字符串中提取英文、数字和中文单词(GPT | 522点数解答 | 2024-05-31 19:05:27)348
- Python:用正则表达式结合 split 思路提取一行字符串中的英文、数字和中文单词 (GPT | 399点数解答 | 2024-05-31 19:07:31)348
- 繁体字编码代码修改:人物名字合法性验证函数转简体版(字节豆包 | 325点数解答 | 2024-10-21 18:57:01)319
- 计算区间 n 到 m 中数字 x 出现次数的 Python 实现与详解(字节豆包 | 289点数解答 | 2025-12-07 17:14:59)113
- Python 实现:计算区间 n 到 m 中数字 x 出现的次数(字节豆包 | 322点数解答 | 2025-12-13 21:37:08)114
- Python实现数字是否为3的倍数判断及输出(字节豆包 | 508点数解答 | 2026-05-31 14:10:46)20
- C++实现数字倍数判断及输出(字节豆包 | 741点数解答 | 2026-05-31 14:11:48)15