DS二分查找_搜索二维矩阵

Description

使用二分查找法来判断m*n矩阵matrix中是否存在目标值target。

该矩阵有以下特性:

  1. 每行中的整数从左到右升序排列;

  2. 每行的第一个整数大于前一行的最后一个整数。

Input

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

接着,输入查找次数t,接着依次输入t个整数target。

Output

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

共输出t行。

Sample

#0
Input

Copy

复制代码
3 4
-1 3 5 7
10 11 16 20
23 30 34 60

3
3
13
16
Output

Copy

复制代码
true
false
true

题目要求:

搜索num在二维矩阵中是否存在,可以直接遍历全部元素,但是可以依据题目条件;

该矩阵有以下特性:

  1. 每行中的整数从左到右升序排列;

  2. 每行的第一个整数大于前一行的最后一个整数。

所以我们可以直接遍历每一行的第一个元素,判断是否存在这个元素,还有是否在这一行

思路:

1.num与第一列每个元素比较一下判断在第几行
2.遍历第几行看能不能查找到num

样例:

1.

2.

3.

关键代码:

判断数在第几行

判断哪一行是否存在着个数

全部代码:

cpp 复制代码
#include <iostream>
#include <string.h>
using namespace std;
const int maxn = 1e2 + 10;
int shuzu[maxn][maxn];
int main()
{
    int n, m;
    while (cin >> n >> m)
    {
        memset(shuzu, 0, sizeof(shuzu));
        for (int i = 1; i <= n; i++)
        {
            for (int j = 1; j <= m; j++)///输入矩阵
            {
                cin >> shuzu[i][j];
            }
        }
        int t;
        cin >> t;
        while (t--)
        {
            int num;
            cin >> num;///要查找的数
            int i = 1;
            for (i = 1; i <= n; i++)
            {
                if (num <= shuzu[i][1])///num找到第一个大于他的数他就在那个数的前一行就是i-1行
                {
                    break;
                }
            }
            if (i == 1)///i=1,说明比第一行最小的数都小,那就不存在这个数
            {
                cout << "false" << endl;
                continue;
            }
            int j;
            for (j = 1; j <= m; j++)///遍历i-1行看看有没有与num相等的数
            {
                if (shuzu[i - 1][j] == num)
                {
                    break;///找到就保留退出循环
                }
            }
            ///tips:数组我开的比较大,所以j如果没找到会变成m+1,如果开的刚刚好的人会出现越界状况
            if (shuzu[i - 1][j] == num)///判断是否与num相等,因为也可能没找到。
            {
                cout << "true" << endl;
            }
            else
            {
                cout << "false" << endl;
            }
        }
    }
    return 0;
}

今天就小小水一下吧!

再见再见再见!!!

相关推荐
05候补工程师1 分钟前
【考研高数核心突破】极限的本质、高频解题套路与海涅定理深度解析(附经典例题思维导图式拆解)
经验分享·笔记·考研·算法
智者知已应修善业5 分钟前
【51单片机8个LED的花样12亮34熄56间隔78闪烁3秒3闪烁】2023-11-4
c++·经验分享·笔记·算法·51单片机
老鱼说AI12 分钟前
统计学习方法第五章:从浅入深解析决策树
人工智能·深度学习·算法·决策树·机器学习·学习方法
KaMeidebaby14 分钟前
卡梅德生物技术快报|蛋白修饰调控 NETosis 分子机制及实验研究进展
前端·数据库·人工智能·算法·百度
初中就开始混世的大魔王18 分钟前
5 Fast DDS-Discovery
网络·c++·算法·中间件
Deep-w18 分钟前
【MATLAB】基于模型预测控制的自适应巡航车辆过渡工况安全控制研究
开发语言·人工智能·算法·机器学习·matlab
运行时记录19 分钟前
Sirchmunk 让搜索随查询自进化
算法
欧米欧21 分钟前
C++进阶数据结构之红黑树
数据结构
浮生望23 分钟前
双指针算法面试通关指南:从入门到精通
算法
SimpleLearingAI26 分钟前
PyTorch & Numpy 实现线性回归详解
人工智能·算法·多模态大模型