Nicn的刷题日常之杨氏矩阵(三种方法求解,逐级递增详解,手把手教学,建议三连收藏)

本文主要是介绍Nicn的刷题日常之杨氏矩阵(三种方法求解,逐级递增详解,手把手教学,建议三连收藏),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1.杨氏矩阵知识普及:什么是样式矩阵 

2.题目描述

3.解题 

3.1暴力求解,遍历法

3.2巧妙解题:对角元素法 

3.3将巧解法封装为函数 

4.结语 


1.杨氏矩阵知识普及:什么是样式矩阵 

      杨氏矩阵,是对组合表示理论和舒伯特演算很有用的工具。它提供了一种方便的方式来描述对称和一般线性群的群表示,并研究它们的性质。有一个二维数组. 数组的每行从左到右是递增的,每列从上到下是递增的. 在这样的数组中查找一个数字是否存在。 时间复杂度小于O(N);

而在C语言中,我们通常理解的矩阵就是二维数组,那么 

即是一个杨氏矩阵 。

2.题目描述

有一个数字矩阵,矩阵的每行从左到右是递增的,矩阵从上到下是递增的,请编写程序在这样的矩阵中查找某个数字是否存在。

要求:时间复杂度小于O(N);

补充时间复杂度:假设数组有N个元素,遍历这个数组的每个元素去找数字最坏的情况就是将所有元素都遍历一遍,找N次,这时就称时间复杂度为O(n)

时间复杂度描述的是速率,描述最坏的数量积

3.解题 

3.1暴力求解,遍历法

这个办法实现的思想是通过遍历数组的每一个元素来找到某个符合要求的数字,如果1考虑最坏的情况,满足要求的数字刚好是最后一个,那就得把数组从第一个元素到最后一个元素都遍历一遍。这样时间复杂度为O(n),但不失为一种办法,我们来实现一下。

int main()
{int arr[3][3] = { 1,2,3,4,5,6,7,8,9 };int input = 0;printf("请输入您要查找的数字:>");scanf("%d", &input);int i = 0;int j = 0;for (i = 0; i < 3; i++){for (j = 0; j < 3; j++){if (arr[i][j] == input){printf("找到了,下标是%d %d\n", i, j);return;}}}printf("很遗憾没有这个数");return 0;
}

 让我们来看一下运行效果:

那我们刚才也说了,遍历法虽然是可行的但是却达不到我们的时间复杂度要求,所以我们得改进方法,介绍我们的第二种方法对角元素法:

3.2巧妙解题:对角元素法 

对于杨氏矩阵来说,有四个位置的数字是特别的,就是四个对角上的元素:

既然如此我们就可以利用数字3和7这两个位置中的任意一个,例如我们就利用3来查找5:

首先将3和5作比较,由于3是第一行最大元素都小于5,那么第一行的元素就排除,我们行数+1,我们看第二行对应1第一行3的位置的数是6,与5比较大于5,那说明要查找的数5就在第二行当时所在位数的列数小于6所在的列数,所以我们行数确定,列数-1,就找到了5. 

我们来看一下实现过程:

int main()
{int arr[3][3] = { 1,2,3,4,5,6,7,8,9 };int input = 0;printf("请输入您要查找的数字:>");scanf("%d", &input);int i = 0;int j = 2;int flag = 0;while (i<=2&&j>=0){if (arr[i][j] < input){i++;//行数增加,列数不变}else if (arr[i][j] > input){j--;//列数减去1}else{printf("找到了,下标是:%d %d\n", i,j);flag = 1;break;}}if (flag == 0)printf("很抱歉没有找到\n");return 0;
}

 

3.3将巧解法封装为函数 

当封装为一个查找函数的时候,我们就不应该在函数内部进行打印,而是应该在函数外部进行打印,那我们的函数就应该要返回横纵坐标,

这样写可以吗?

return  x,y;

明显这样的返回值是错误的,x,y会被当做为一个逗号表达式进行看待。

所以这里我是直接进行传地址,利用指针传参。我们看一下实现:

void Yang_table_serch(int arr[3][3], int k, int* r, int* c)
{int i = 0;int j = *c - 1;int flag = 0;while (i <= *c-1 && j >= 0){if (arr[i][j] < k){i++;//行数增加,列数不变}else if (arr[i][j] >k){j--;//列数减去1}else{*r = i;*c = j;flag = 1;return;}}if (flag == 0)*r = -1;*c = -1;return;}
int main()
{int arr[3][3] = { 1,2,3,4,5,6,7,8,9 };int input = 0;printf("请输入您要查找的数字:>");scanf("%d", &input);int i = 0;int j = 2;Yang_table_serch(arr, input, &i, &j);if (i == -1 && j == -1){printf("没有找到\n");}else{printf("找到了,下标是:%d %d\n", i, j);}return 0;
}

 

4.结语 

以上就是本期的所有内容,知识含量蛮多,大家可以配合解释和原码运行理解。创作不易,大家如果觉得还可以的话,欢迎大家三连,有问题的地方欢迎大家指正,一起交流学习,一起成长,我是Nicn,正在c++方向前行的奋斗者,感谢大家的关注与喜欢。

      

这篇关于Nicn的刷题日常之杨氏矩阵(三种方法求解,逐级递增详解,手把手教学,建议三连收藏)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/677638

相关文章

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

Redis 的 SUBSCRIBE命令详解

《Redis的SUBSCRIBE命令详解》Redis的SUBSCRIBE命令用于订阅一个或多个频道,以便接收发送到这些频道的消息,本文给大家介绍Redis的SUBSCRIBE命令,感兴趣的朋友跟随... 目录基本语法工作原理示例消息格式相关命令python 示例Redis 的 SUBSCRIBE 命令用于订

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

JavaScript中的高级调试方法全攻略指南

《JavaScript中的高级调试方法全攻略指南》什么是高级JavaScript调试技巧,它比console.log有何优势,如何使用断点调试定位问题,通过本文,我们将深入解答这些问题,带您从理论到实... 目录观点与案例结合观点1观点2观点3观点4观点5高级调试技巧详解实战案例断点调试:定位变量错误性能分

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e

SpringBoot日志级别与日志分组详解

《SpringBoot日志级别与日志分组详解》文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或... 目录日志级别1、级别内容2、调整日志级别调整默认日志级别调整指定类的日志级别项目开发过程中,利用日志

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有