当前位置: 首页> 娱乐> 明星 > 最近一周的热点新闻_桂林网站制作公司华彩_关键词优化需要从哪些方面开展?_今天的新闻 最新消息摘抄

最近一周的热点新闻_桂林网站制作公司华彩_关键词优化需要从哪些方面开展?_今天的新闻 最新消息摘抄

时间:2025/7/15 16:09:48来源:https://blog.csdn.net/ml29895063/article/details/146588581 浏览次数:1次
最近一周的热点新闻_桂林网站制作公司华彩_关键词优化需要从哪些方面开展?_今天的新闻 最新消息摘抄

题目链接:搜索二维矩阵

虽然本题使用二分法,但二分的写法有很多种,所以在判断 target 大小与有序部分的关系的时候可能会出现细节上的差别。

1、 本题则是与常用代码不同的是:

else if(target<matrix[midRow][columnR])
{
rowH=midRow+1; //本题要改为rowH=midRow,
}
else{
rowL=midRow+1;
}

因为当target<matrix[midRow][columnR]时,target是小于midRow这一行的最右侧的最大元素,而这一行的其他比最右侧元素小的元素与target的关系未知。所以,应该rowH=midRow,而不是rowH=midRow+1。这是为了防止target在矩阵中存在,但是没有搜索到。
2、另一个不同的地方就是二分法的终止条件要从while(l<=r)改为while(l<r)。这是为了防止l或者r越上界或者下界。

c++代码实现

class Solution {
public:bool searchMatrix(vector<vector<int>>& matrix, int target) {int columnL=0,columnR=matrix[0].size()-1;int rowL=0, rowH=matrix.size()-1;if(columnR==0 && rowH==0){if(matrix[0][0]==target){return true;}else{return false;}}while (rowL<rowH){int midRow = (rowL+rowH)/2;if(target == matrix[midRow][columnR]){return true;}else if(target<matrix[midRow][columnR]){rowH=midRow;}else{rowL=midRow+1;}}if(matrix[rowL][columnL]==target){return true;}//处理行:rowL行while(columnL<columnR){int midColumn=(columnL+columnR)/2;if(target==matrix[rowL][midColumn]){return true;}else if(target<=matrix[rowL][midColumn]){columnR=midColumn;}else{columnL=midColumn+1;}}  if(matrix[rowL][columnL]==target){return true;}return false;}
};
关键字:最近一周的热点新闻_桂林网站制作公司华彩_关键词优化需要从哪些方面开展?_今天的新闻 最新消息摘抄

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: