[c语言日寄]在不完全递增序中查找特定要素

【作者主页】siy2333

【专栏介绍】⌈c语言日寄⌋:这是一个专注于C语言刷题的专栏,精选题目,搭配详细题解、拓展算法。从基础语法到复杂算法,题目涉及的知识点全面覆盖,助力你系统提升。无论你是初学者,还是进阶开发者,这里都能满足你的需求!

【食用方法】1.根据题目自行尝试 2.查看基础思路完善题解 3.学习拓展算法

【Gitee链接】资源保存在我的Gitee仓库:https://gitee.com/siy2333/study


文章目录


前言

查找类问题是一个非常常见的任务。无论是从简单的数组中查找一个特定的数字,还是从复杂的数据结构中检索信息,查找算法的效率和正确性都十分重要。今天,我们将探讨一个有趣的查找问题:在不完全递增序的矩阵中查找特定的元素。


一、题目引入

不完全递增矩阵

假设我们有一个二维矩阵,矩阵的每一行从左到右是递增的,但列与列之间并没有严格的递增关系。这种矩阵被称为"不完全递增序矩阵"。

例如,以下矩阵满足这一条件

1 3 5 7
2 4 6 8
10 11 12 13
9 14 15 16

在这个矩阵中,每一行都是递增的 ,但列与列之间并不完全递增

问题描述

给定一个不完全递增序的矩阵和一个目标数字,编写一个程序来判断该数字是否存在于矩阵中。

假设矩阵如下,而且目标数字为 12:

1 3 5 7
2 4 6 8
10 11 12 13
9 14 15 16

此时,程序返回 true。

二、知识点分析

  1. 矩阵的特性
    矩阵的每一行从左到右是递增的,这意味着我们可以利用这一特性来优化查找算法。虽然列与列之间没有严格的递增关系,但行的递增性仍然可以为我们提供一些线索。我们在接下来的文章中会利用这一点解题。
  2. 查找算法
    在完全有序的矩阵中,我们可以从右上角或左下角开始查找,利用矩阵的有序性逐步缩小搜索范围(例如二分查找)。然而,在不完全递增序的矩阵中,这种方法不再适用。我们需要寻找一种新的策略来优化查找过程。
  3. 时间复杂度
    对于一个 M×N 的矩阵,暴力搜索的时间复杂度为 O(M×N)。

三、解法实现与分析

1. 暴力搜索

最简单的查找方法是暴力搜索,即遍历矩阵的每一个元素,检查是否等于目标值。这种方法的时间复杂度为 O(M×N),效率较低。

c 复制代码
#include <stdio.h>
#include <stdbool.h>

#define M 4
#define N 4

//暴力查找函数
bool find_brute_force(int matrix[M][N], int target) {
    for (int i = 0; i < M; i++) {
        for (int j = 0; j < N; j++) {
            if (matrix[i][j] == target) {
                return true;
            }
        }
    }
    return false;
}
//主函数
int main() {
	//定义数组
    int matrix[M][N] = {
        {1, 3, 5, 7},
        {2, 4, 6, 8},
        {10, 11, 12, 13},
        {9, 14, 15, 16}
    };

    int target = 12;
    //查找与输出
    if (find_brute_force(matrix, target)) {
        printf("Target %d found in the matrix.\n", target);
    } else {
        printf("Target %d not found in the matrix.\n", target);
    }

    return 0;
}

运行结果如下:

2. 逐行二分查找

虽然矩阵的列没有严格的递增关系,但每一行的递增性可以被利用。我们可以对每一行进行二分查找。这种方法的时间复杂度为 O(MlogN)

c 复制代码
#include <stdio.h>
#include <stdbool.h>

#define M 4
#define N 4

bool binary_search(int arr[], int target) {
    int left = 0, right = N - 1;
    while (left <= right) {
        int mid = left + (right - left) / 2;
        if (arr[mid] == target) {
            return true;
        } else if (arr[mid] < target) {
            left = mid + 1;
        } else {
            right = mid - 1;
        }
    }
    return false;
}

bool find_row_wise(int matrix[M][N], int target) {
    for (int i = 0; i < M; i++) {
        if (binary_search(matrix[i], target)) {
            return true;
        }
    }
    return false;
}

int main() {
    int matrix[M][N] = {
        {1, 3, 5, 7},
        {2, 4, 6, 8},
        {10, 11, 12, 13},
        {9, 14, 15, 16}
    };

    int target = 12;
    if (find_row_wise(matrix, target)) {
        printf("Target %d found in the matrix.\n", target);
    } else {
        printf("Target %d not found in the matrix.\n", target);
    }

    return 0;
}

运行结果如下:

四、总结

通过分析条件的特性,选择合适的查找算法和数据结构,是程序员的重要素质。对于这道题,即不完全递增序的矩阵,逐行二分查找是一种有效的优化策略。

关注窝,每三天至少更新一篇优质c语言题目详解~

专栏链接QwQ\] :[⌈c语言日寄⌋CSDN](https://blog.csdn.net/2401_83741734/category_12881323.html) \[关注博主ava\]:[siy2333](https://blog.csdn.net/2401_83741734?spm=1011.2266.3001.5343) 感谢观看\~ 我们下次再见!!

相关推荐
李日灐21 小时前
C++进阶必备:红黑树从 0 到 1: 手撕底层,带你搞懂平衡二叉树的平衡逻辑与黑高检验
开发语言·数据结构·c++·后端·面试·红黑树·自平衡二叉搜索树
YuTaoShao21 小时前
【LeetCode 每日一题】3634. 使数组平衡的最少移除数目——(解法二)排序 + 二分查找
数据结构·算法·leetcode
wangluoqi21 小时前
26.2.6练习总结
数据结构·算法
Risehuxyc21 小时前
备份三个PHP程序
android·开发语言·php
Q741_1471 天前
C++ 优先级队列 大小堆 模拟 力扣 703. 数据流中的第 K 大元素 每日一题
c++·算法·leetcode·优先级队列·
lly2024061 天前
PHP Error: 常见错误及其解决方法
开发语言
森焱森1 天前
嵌入式硬件工程师应知 白银快速分析报告
linux·c语言·arm开发·嵌入式硬件·去中心化
网安墨雨1 天前
Python自动化一------pytes与allure结合生成测试报告
开发语言·自动化测试·软件测试·python·职场和发展·自动化
毕设源码李师姐1 天前
计算机毕设 java 基于 java 的图书馆借阅系统 智能图书馆借阅综合管理平台 基于 Java 的图书借阅与信息管理系统
java·开发语言·课程设计
忆~遂愿1 天前
Runtime 上下文管理:计算实例的生命周期、延迟最小化与上下文切换优化
java·大数据·开发语言·人工智能·docker