[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) 感谢观看\~ 我们下次再见!!

相关推荐
梦境虽美,却不长27 分钟前
算法 学习 排序 2025年6月16日10:25:37
数据结构·学习·排序算法
全干engineer35 分钟前
Web3-Web3.js核心操作:Metamask、合约调用、事件订阅全指南
开发语言·javascript·web3·区块链·智能合约
speop44 分钟前
【datawhale组队学习】共读AI新圣经
人工智能·学习
羑悻的小杀马特1 小时前
从信息孤岛到智能星云:学习助手编织高校学习生活的全维度互联网络
c++·学习·生活·api
刘一说1 小时前
资深Java工程师的面试题目(六)数据存储
java·开发语言·数据库·面试·性能优化
江沉晚呤时1 小时前
EventSourcing.NetCore:基于事件溯源模式的 .NET Core 库
java·开发语言·数据库
-qOVOp-1 小时前
408第一季 - 数据结构 - 排序II
数据结构·算法·排序算法
小胖同学~1 小时前
快速入门数据结构--栈
算法
C++ 老炮儿的技术栈1 小时前
VSCode -配置为中文界面
大数据·c语言·c++·ide·vscode·算法·编辑器
火鸟21 小时前
Rust 通用代码生成器:莲花,红莲尝鲜版三十六,哑数据模式图片初始化功能介绍
开发语言·后端·rust·通用代码生成器·莲花·红莲·图片初始化功能