当前位置: 首页 > ops >正文

leetcode 498. 对角线遍历 中等

给你一个大小为 m x n 的矩阵 mat ,请以对角线遍历的顺序,用一个数组返回这个矩阵中的所有元素。

示例 1:

输入:mat = [[1,2,3],[4,5,6],[7,8,9]]
输出:[1,2,4,7,5,3,6,8,9]

示例 2:

输入:mat = [[1,2],[3,4]]
输出:[1,2,3,4]

提示:

  • m == mat.length
  • n == mat[i].length
  • 1 <= m, n <= 10^4
  • 1 <= m * n <= 10^4
  • -10^5 <= mat[i][j] <= 10^5

分析:直接模拟。由于矩阵的大小不会很大,可以额外用一个数组标记位置是否已经遍历过。

/*** Note: The returned array must be malloced, assume caller calls free().*/
int* findDiagonalOrder(int** mat, int matSize, int* matColSize, int* returnSize) {int n=matSize,m=matColSize[0],f=0,t=0;*returnSize=m*n;int flag[n+5][m+5];for(int i=0;i<n;++i)for(int j=0;j<m;++j)flag[i][j]=0;int *ans=(int*)malloc(sizeof(int)*(m*n));for(int i=0,j=0;t<m*n;){if(!f){while(i>=0&&j<m&&flag[i][j]==0){ans[t++]=mat[i][j],flag[i][j]=1;i--,j++;}f=1;i++;j=fmin(m-1,j);}else{while(i<n&&j>=0&&flag[i][j]==0){ans[t++]=mat[i][j],flag[i][j]=1;i++,j--;}f=0;j++;i=fmin(n-1,i);}}return ans;
}

http://www.xdnf.cn/news/18676.html

相关文章:

  • (论文速读)FloVD:光流遇见视频扩散模型,开启相机控制视频生成
  • RAG实现多语言客户端的技术方案
  • Claude Code 使用及配置智能体
  • MQTT协议详解:从基础原理到工业级实践指南
  • CANopen - DCF(Device Configuration File) 介绍
  • Apache Maven 3.1.1 (eclipse luna)
  • MATLAB 绘制根轨迹、Bode图的方法
  • 扭蛋机小程序系统开发:连接线上线下娱乐的新桥梁
  • 掌握C++ std::invoke_result_t:类型安全的函数返回值提取利器
  • 在Excel和WPS表格中拼接同行列对称的不连续数据
  • Docker Compose 部署 Elasticsearch 8.12.2 集成 IK 中文分词器完整指南
  • python面试题目100个(更新中预计10天更完)
  • LangChain4J-(2)-高阶API与低阶API
  • 汽车零部件工厂ESOP系统工业一体机如何选型
  • 基于51单片机红外避障车辆高速汽车测速仪表设计
  • 简述Myisam和Innodb的区别?
  • C++17 中std::any 详解和代码示例
  • 【LeetCode 热题 100】416. 分割等和子集——(解法一)记忆化搜索
  • ansible的搭建与安装
  • 在数字化转型过程中,如何确保数据安全和隐私保护?
  • Linux 软件编程(十一)网络编程:TCP 机制与 HTTP 协议
  • 我的项目管理之路-组织级项目管理(二)
  • 【spring进阶】spring应用内方法调用时长统计
  • 【C语言强化训练16天】--从基础到进阶的蜕变之旅:Day13
  • Python之matplotlib 基础三:绘制折线图
  • 什么是JSON-RPC 2.0,在项目中应该怎么使用
  • Jenkins+docker 微服务实现自动化部署安装和部署过程
  • More Effective C++ 条款08:理解各种不同意义的new和delete
  • (操作系统)死锁是什么 必要条件 解决方式
  • 【Task05】:向量数据库实践(第三章3、4节)