cde网站_zaqxswcde

cde网站_zaqxswcde给定一个 m x n 整数矩阵 matrix ,找出其中 最长递增路径 的长度。对于每个单元格,你可以往上,下,左,右四个方向移动。 你 不能 在 对角线 方向上移动或移动到 边界外(即不允许环绕)。示例 1:输入:matrix = [[9,9,4],[6,6,8],[2,1,1]]输出:4 解释:最长递增路径为 [1, 2, 6, 9]。示例 2:输入:matrix = [[3,4,5],[3,2,6],[2,2,1]]输出:4 解释:最长递增路径是 [3, 4, 5, 6]。注意

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

给定一个 m x n 整数矩阵 matrix ,找出其中 最长递增路径 的长度。

对于每个单元格,你可以往上,下,左,右四个方向移动。 你 不能 在 对角线 方向上移动或移动到 边界外(即不允许环绕)。

示例 1:

在这里插入图片描述

输入:matrix = [[9,9,4],[6,6,8],[2,1,1]]
输出:4 
解释:最长递增路径为 [1, 2, 6, 9]

示例 2:

在这里插入图片描述

输入:matrix = [[3,4,5],[3,2,6],[2,2,1]]
输出:4 
解释:最长递增路径是 [3, 4, 5, 6]。注意不允许在对角线方向上移动。

示例 3:

输入:matrix = [[1]]
输出:1
 

提示:

m == matrix.length
n == matrix[i].length
1 <= m, n <= 200
0 <= matrix[i][j] <= 231 – 1

  1. 拓扑排序
const int N = 4e4 + 10;
const int M = 4 * N;
const int INF = 0x3f3f3f3f;
class Solution { 

public:
int dx[4] = { 
0,1,0,-1},dy[4] = { 
-1,0,1,0};
int n,m;
struct Edge{ 

int v,next;
}edge[M];
int head[N],cnt;
void add(int u,int v){ 

edge[cnt].v = v;
edge[cnt].next = head[u];
head[u] = cnt ++;
}
int in[N];
int q[N],hh = 0,tt = 0;
int dist[N];
int get(int x,int y){ 

return x * m + y;
}
int topsort(){ 

memset(dist,0,sizeof dist);
for(int i = 0;i < n * m;i ++){ 

if(in[i] == 0)q[tt ++] = i,dist[i] = 0;
}
while(hh != tt){ 

int t = q[hh ++];
if(hh == N)hh = 0;
for(int i = head[t];~i;i = edge[i].next){ 

int v = edge[i].v;
dist[v] = max(dist[v],dist[t] + 1);
in[v] --;
if(in[v] == 0){ 

q[tt ++] = v;
if(tt == N)tt = 0;
}
}
}
int res = 0;
for(int i = 0;i < n * m;i ++)res = max(res,dist[i]);
return res + 1;
}
int longestIncreasingPath(vector<vector<int>>& matrix) { 

n = matrix.size(),m = matrix[0].size();
memset(head,-1,sizeof head);
cnt = 0;
for(int i = 0;i < n;i ++){ 

for(int j = 0;j < m;j ++){ 

for(int k = 0;k < 4;k ++){ 

int a = i + dx[k],b = j + dy[k];
if(a < 0 || a >= n || b < 0 || b >= m)continue;
if(matrix[i][j] > matrix[a][b]){ 

add(get(i,j),get(a,b));
in[get(a,b)] ++;
}
}
}
}
int ans = topsort();
return ans;
}
};
  1. 记忆化搜索
const int N = 210;
class Solution { 

public:
int rem[N][N];
bool st[N][N];
int n,m;
int dx[4] = { 
0,1,0,-1},dy[4] = { 
-1,0,1,0};
int dfs(int i,int j,vector<vector<int>>& matrix){ 

int &r = rem[i][j];
int ma = 0;
if(r > 0)return r;
for(int k = 0;k < 4;k ++){ 

int a = i + dx[k],b = j + dy[k];
if(a < 0 || a >= n || b < 0 || b >= m || matrix[i][j] >= matrix[a][b])continue;
ma = max(ma,dfs(a,b,matrix));
}
r = ma + 1;
return r;
}
int longestIncreasingPath(vector<vector<int>>& matrix) { 

n = matrix.size(),m = matrix[0].size();
int res = 0;
for(int i = 0;i < n;i ++){ 

for(int j = 0;j < m;j ++){ 

res = max(res,dfs(i,j,matrix));
}
}
return res;
}
};
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/168541.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • 对标 VS Code,JetBrains 的下一代 IDE :Fleet[通俗易懂]

    对标 VS Code,JetBrains 的下一代 IDE :Fleet[通俗易懂]昨天(11月29日),JetBrains网站上出现了一个全新的IDE–Fleet它是谁呢?这软件的风格,怎么看都不像JB的亲儿子。。不过,我很负责任地告诉,这就是JetBrains的下一代IDE,妥妥的亲儿子。目前Fleet还处于开发阶段,还没有开放下载使用,如果你想尝鲜,可以通过这个链接(https://www.jetbrains.com/fleet/preview/)填写一下表格申请。看到这个消息,我就赶紧去申请了,但何时会通过,官方表示也不清楚。虽然还无法使

  • 如何让phpmyadmin输入密码再进入

    如何让phpmyadmin输入密码再进入

  • Qt编写视频播放器(vlc内核)[通俗易懂]

    Qt编写视频播放器(vlc内核)[通俗易懂]在研究qt+vlc的过程中,就想直接做个播放器用于独立的项目,vlc还支持硬件加速,不过部分电脑硬件不支持除外。用vlc的内核写播放器就是快,直接调用api就行,逻辑处理和ui展示基本上分分钟的事情,

  • pytest parametrize fixture_参数化方法

    pytest parametrize fixture_参数化方法前言当某个接口中的一个字段,里面规定的范围为1-5,你5个数字都要单独写一条测试用例,就太麻烦了,这个时候可以使用pytest.mark.parametrize装饰器可以实现测试用例参数化。官方示

  • git如何移除某文件的版本控制

    git如何移除某文件的版本控制

    2021年10月20日
  • 【C/C++面试必备】volatile 关键字

    【C/C++面试必备】volatile 关键字????作者:Linux猿????简介:CSDN博客专家????,C/C++、面试、刷题、算法尽管咨询我,关注我,有问题私聊!????关注专栏:C/C++面试通关集锦(优质好文持续更新中……)????本文来讲解一下C/C++中的关键字volatile。在日常的使用中很少使用到,但是,在面试中经常被提起,下面具体来看一下。volatile的作用是什么呢?volatile意思是易变的,是一种类型修饰符,在C/C++中用来阻止编译器因误认某段代码无法被代码本身所改变,而造成的

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号