马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有账号?立即注册
x
方法一:两次二分查找
- class Solution {
- public:
- bool searchMatrix(vector<vector<int>> matrix, int target) {
- auto row = upper_bound(matrix.begin(), matrix.end(), target, [](const int b, const vector<int> &a) {
- return b < a[0];
- });
- if (row == matrix.begin()) {
- return false;
- }
- --row;
- return binary_search(row->begin(), row->end(), target);
- }
- };
复制代码 方法二:一次二分查找
- class Solution {
- public:
- bool searchMatrix(vector<vector<int>>& matrix, int target) {
- int m = matrix.size(), n = matrix[0].size();
- int low = 0, high = m * n - 1;
- while (low <= high) {
- int mid = (high - low) / 2 + low;
- int x = matrix[mid / n][mid % n];
- if (x < target) {
- low = mid + 1;
- } else if (x > target) {
- high = mid - 1;
- } else {
- return true;
- }
- }
- return false;
- }
- };
复制代码 leetcode题解
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |