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

news2024/9/23 7:23:20

目录

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++方向前行的奋斗者,感谢大家的关注与喜欢。

      

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1430900.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

计算机网络_1.6.3 计算机网络体系结构分层思想举例

1.6.3 计算机网络体系结构分层思想举例 1、实例引入&#xff08;用户在主机中使用浏览器访问web服务器&#xff09;2、从五层原理体系结构的角度研究该实例3、练习题 笔记来源&#xff1a; B站 《深入浅出计算机网络》课程 本节通过一个常见的网络应用实例&#xff0c;来介绍计…

“type-check“ exited with 1.

博主介绍&#xff1a;✌全网粉丝5W&#xff0c;全栈开发工程师&#xff0c;从事多年软件开发&#xff0c;在大厂呆过。持有软件中级、六级等证书。可提供微服务项目搭建与毕业项目实战&#xff0c;博主也曾写过优秀论文&#xff0c;查重率极低&#xff0c;在这方面有丰富的经验…

ProcessSlot构建流程分析

ProcessorSlot ProcessorSlot构建流程 // com.alibaba.csp.sentinel.CtSph#lookProcessChain private Entry entryWithPriority(ResourceWrapper resourceWrapper, int count, boolean prioritized, Object... args)throws BlockException {// 省略创建 Context 的代码// 黑盒…

gorm day1

gorm day1 gorm简介gorm声明模型 代码样例基本来自官方文档 Gorm简介 什么是ORM&#xff1f; 对象关系映射(Objection Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库(如mysql数据库&#xff09;存在的互不匹配现象的计数。简单来说&#xff0c;ORM是通…

【annie/lux 快速下载哔哩哔哩视频】全网最简单,只需要5步!!!

1.首先 现在annie更名为lux 官网地址&#xff1a;https://github.com/iawia002/lux/releases 2.进入官网之后如图所示 3.下载lux软件 4.下载lux 这里需要说明一下 如果不下载这个的话也可以下载视频 但是视频和音频是分开的&#xff0c;你的视频没有声音 5.下载视频

04、全文检索 -- Solr -- 管理 Solr 的 core(使用命令和图形界面创建、删除 core,以及对core 目录下的各文件进行详细介绍)

目录 管理 Solr 的 core创建 Core方式1&#xff1a;solr 命令创建演示&#xff1a;使用 solr 命令创建 Core&#xff1a;演示&#xff1a;命令删除 Core&#xff08;彻底删除&#xff09; 方式2&#xff1a;图形界面创建Web控制台创建CoreWeb控制台删除 Core&#xff08;未彻底…

软件测试学习笔记-测试用例的编写

7中测试分类 按照阶段可划分单元测试、集成测试、系统测试、验收测试。代码可见度划分黑盒测试、灰盒测试、白盒测试 单元测试&#xff1a;针对源代码的测试 集成测试&#xff1a;针对接口进行测试 系统测试&#xff1a;针对功能和非功能的测试 验收测试&#xff1a;公测、内测…

js中执行上下文和执行栈是什么

文章目录 一、执行上下文二、生命周期创建阶段This Binding词法环境变量环境 执行阶段回收阶段 二、执行栈参考文献 一、执行上下文 简单的来说&#xff0c;执行上下文是一种对Javascript代码执行环境的抽象概念&#xff0c;也就是说只要有Javascript代码运行&#xff0c;那么…

关于Django部署

首先了解一下开发环境服务器跟生产环境服务器有何不同。 一、我们通过 python manage.py runserver 启动开发环境服务器&#xff0c;这条命令背后做了哪些事情&#xff1f; 1、首先加载Django项目的设置&#xff08;settings&#xff09; 2、检查数据库迁移&#xff0c;确保数…

这种学习单片机的顺序是否合理?

这种学习单片机的顺序是否合理&#xff1f; 在开始前我有一些资料&#xff0c;是我根据网友给的问题精心整理了一份「单片机的资料从专业入门到高级教程」&#xff0c; 点个关注在评论区回复“888”之后私信回复“888”&#xff0c;全部无偿共享给大家&#xff01;&#xff01…

【Linux Day15 TCP网络通讯】

TCP网络通讯 TCP编程流程 接口介绍 socket()方法是用来创建一个套接字&#xff0c;有了套接字就可以通过网络进行数据的收发。创建套接字时要指定使用的服务类型&#xff0c;使用 TCP 协议选择流式服务&#xff08;SOCK_STREAM&#xff09;。 **bind()方法是用来指定套接字使…

绝地求生:海外博主呼吁PUBG2开发提上日程,PUBG2能否继往日荣光

海外PUBG博主WackyJacky101发推&#xff1a;PUBG 现在的平均玩家人数继续增加&#xff0c;但假期过后这里的势头似乎正在放缓&#xff01;现在是保持势头并宣布制作 PUBG 2 的最佳时机&#xff01; 大家好&#xff0c;我是闲游盒。PUBG作为最早的独立大逃杀游戏之一&#xff0c…

你今年过年回去吗?

#过年 我是一名21岁刚毕业的大学生&#xff0c;专业是软件技术&#xff0c;主修c#&#xff0c;之前在上海实习了一年&#xff0c;正式工作后来到了深圳&#xff0c;进入了一家电商公司实习。至于我为什么转行了&#xff0c;大家懂的都懂 现在是20240203晚上19.39&#xff0c;还…

算法设计与分析实验:回溯

目录 一、组合总和 1.1 具体思路 1.2 思路展示 1.3 代码实现 1.4 复杂度分析 1.5 运行结果 二、全排列 2.1 具体思路 2.2 思路展示 2.3 代码实现 2.4 复杂度分析 2.5 运行结果 三、N皇后问题 3.1 具体思路 3.2 思路展示 3.3 代码实现 3.4 复杂度分析 3.5 运行…

两个重要极限【高数笔记】

【第一个&#xff1a;lim &#xff08;sinx / x&#xff09; 1, x -- > 0】 1.本质&#xff1a; lim &#xff08;sin‘&#xff1f;’ / ‘&#xff1f;’&#xff09; 1, ‘&#xff1f;’ -- > 0&#xff1b;保证‘&#xff1f;’ -- > 0,与趋向无关 2.例题&#x…

Harbor介绍、整体架构和安装

1.Harbor介绍 Harbor 是由 VMware 开源的一款云原生制品仓库&#xff0c;Harbor 的核心功能是存储和管理 Artifact。Harbor 允许用户用命令行工具对容器镜像及其他 Artifact 进行推送和拉取&#xff0c;并提供了图形管理界面帮助用户查看和管理这些 Artifact。在 Harbor 2.0 版…

LangChain 81 LangGraph 从入门到精通三

LangChain系列文章 LangChain 60 深入理解LangChain 表达式语言23 multiple chains链透传参数 LangChain Expression Language (LCEL)LangChain 61 深入理解LangChain 表达式语言24 multiple chains链透传参数 LangChain Expression Language (LCEL)LangChain 62 深入理解Lang…

Logback学习

logback 1、logback介绍 Logback是由log4j创始人设计的另一个开源日志组件&#xff0c;性能比log4j要好。 lockback优点&#xff1a; 内核重写、测试充分、初始化内存加载更小&#xff0c;这一切让logback性能和log4j相比有诸多倍的提升。logback非常自然地直接实现了slf4j…

Open3d计算点云法向量,可视化(代码)

Open3d使用estimate_normals函数来计算法向量。其参数设置Open3d提供了3中参数搜索的方法&#xff08;所有计算的法向量模长为1&#xff09;&#xff1a; open3d.geometry.KDTreeSearchParamKNN(knn20) # 计算近邻的20个点 open3d.geometry.KDTreeSearc…

SVDiff: Compact Parameter Space for Diffusion Fine-Tuning——【论文笔记】

本文发表于ICCV 2023 论文地址&#xff1a;ICCV 2023 Open Access Repository (thecvf.com) 官方代码&#xff1a;mkshing/svdiff-pytorch: Implementation of "SVDiff: Compact Parameter Space for Diffusion Fine-Tuning" (github.com) 一、Introduction 最近几…