E : B DS二分查找_搜索二维矩阵

这篇具有很好参考价值的文章主要介绍了E : B DS二分查找_搜索二维矩阵。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Description

使用二分查找法来判断m*n矩阵matrix中是否存在目标值target。
该矩阵有以下特性:

  1. 每行中的整数从左到右升序排列;
  2. 每行的第一个整数大于前一行的最后一个整数。

Input

第一行输入m和n,分别表示矩阵的行数和列数,接着输入m*n个整数。
接着,输入查找次数t,接着依次输入t个整数target。

Output

对于每次查找,若target存在于矩阵中,则输出true,否则输出false。
共输出t行。

Sample

#0

Input

3 4
-1 3 5 7
10 11 16 20
23 30 34 60

3
3
13
16

Output

true
false
true

Hint

1 <= m, n <= 100
-10^4 <= matrix[i][j], target <= 10^4文章来源地址https://www.toymoban.com/news/detail-760971.html

AC代码

#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
const int N = 101;
int matrix[N][N];
int target;

bool checkRow(int x)
{
	return matrix[x][0] > target;
}
bool check(int x, int row, bool& ret)
{
	if (matrix[row][x] == target)ret = true;
	return matrix[row][x] > target;
}
//target是要查找的值  m为行数,n为列数
bool MatrixBinarySearch( int m,int n)
{
	int l, r;
	bool ret = false;

	l = 0, r = m ;//先利用二分法判断target可能在哪一行中
	while (l < r)
	{
		int mid = l + r >> 1;
		if (checkRow(mid))r = mid;
		else l = mid +1;
	}

	int row = l-1;//将确定好的行保存

	l = 0, r = n ;
	while (l < r)//在确定可能存在target的行中二分查找
	{
		int mid = l + r >> 1;
		if (check(mid,row,ret))r = mid;
		else l = mid + 1;
	}

	return ret;
}


int main()
{
	int m, n;
	cin >> m >> n;
	for (int i = 0; i < m; i++)
	{
		for (int j = 0; j < n; j++) {
			cin >> matrix[i][j];
		}
	}
	int t;
	cin >> t;
	while (t--)
	{
		cin >> target;
		bool ret = MatrixBinarySearch(  m, n);
		if (ret)cout << "true" << endl;
		else cout << "false" << endl;
	}
	return 0;
}

到了这里,关于E : B DS二分查找_搜索二维矩阵的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数据结构,查找算法(二分,分块,哈希)

    一、查找算法         1、二分查找:(前提条件: 必须有序的序列) 2、分块查找:(块间有序,块内无序)     索引表  +  源数据表     思路:     (1)先在索引表中确定在哪一块中     (2)再遍历这一块进行查找 //索引表 typedef  struct  {     int max; //块中最大值

    2024年02月11日
    浏览(57)
  • Java数据结构与算法:查找算法之二分查找

    大家好,我是免费搭建查券返利机器人赚佣金就用微赚淘客系统3.0的小编,欢迎回到本专栏。在这个冰冷的季节里,我们将一同探讨Java中一种高效的查找算法——二分查找。让我们点燃知识的火花,一同解锁这个查找奇迹的秘密! 二分查找简介 二分查找,也称为折半查找,

    2024年01月21日
    浏览(45)
  • 数据结构-查找(顺序查找与二分查找的讲解与代码实现)

    顺序查找概念:从表的另一端开始,一次将记录的和给定值进行比较,若某个记录的和给定的值相等,则查找成功,反之则查找失败。 ASL:平均查找长度 pi查找概率,ci查找次数 eg:序列1,2,3 查找1的次数为1概率为1/3,2为两次概率1/3,3的次数为3概率1/3  将12

    2024年02月06日
    浏览(68)
  • 【手撕数据结构】二分查找(好多细节)

    🌈键盘敲烂,年薪30万🌈 目录 普通版本的二分查找: right只负责控制边界(少了两次比较): 时间复杂度更稳定的版本: BSLeftmost: BSRightmost:   🏸细节1:循环判定条件是left = right ⭐细节2:mid = (left + right ) 1 原因见代码注释 改动1:while条件是left right 改动2:right = nums.len

    2024年02月05日
    浏览(47)
  • Python数据结构与算法篇(五)-- 二分查找与二分答案

    1.1 定义         二分查找又称折半查找、二分搜索、折半搜索等,是一种在静态查找表中查找特定元素的算法。         所谓静态查找表,即只能对表内的元素做查找和读取操作,不允许插入或删除元素。         使用二分查找算法,必须保证查找表中存放的是有

    2023年04月20日
    浏览(45)
  • 数据结构和算法之二分法查找

    二分法查找,也称作 二分查找 或 折半查找 ,是一种在有序数组中快速查找特定元素的算法。它采用分治法思想,通过将问题划分为规模更小的子问题,并且通过对子问题的查找来解决原问题。 二分法查找的思路是不断地将数组一分为二,然后判断目标值在哪一部分,进而

    2024年02月09日
    浏览(46)
  • 【数据结构与算法】python实现二分查找

    二分查找 又称折半查找,它是一种效率较高的查找方法 原理:首先,假设表中元素是按升序排列,将表中间位置记录的与查找比较,如果两者相等,则查找成功;否则利用中间位置记录将表分成前、后两个子表,如果中间位置记录的大于查找,则

    2024年02月05日
    浏览(40)
  • 浙大数据结构第一周01-复杂度3 二分查找

    本题要求实现二分查找算法。 函数接口定义: 其中 List 结构定义如下: L 是用户传入的一个线性表,其中 ElementType 元素可以通过、==、进行比较,并且题目保证传入的数据是递增有序的。函数 BinarySearch 要查找 X 在 Data 中的位置,即数组下标(注意:元素从下标1开始存储)

    2024年02月12日
    浏览(46)
  • 搜索二维矩阵【二分】

    Problem: 74. 搜索二维矩阵 可以二分一次,也可以二分两次。 时间复杂度: 添加时间复杂度, 示例: O ( l o g n + l o g m ) O(logn + logm) O ( l o g n + l o g m ) 空间复杂度: 添加空间复杂度, 示例: O ( 1 ) O(1) O ( 1 )

    2024年02月02日
    浏览(32)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包