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

网站链接怎么做标记博客是哪个软件

网站链接怎么做标记,博客是哪个软件,仙居县建设规划局网站,新泰网站制作5.LC 零矩阵(中等) 面试题 01.08. 零矩阵 - 力扣(LeetCode) 思想: 法一: 利用两个集合分别储存要清0的行和列索引 另外两种原地优化空间的做法暂时不是目前刷题目标,故不考虑 代码 c: class Solution { public:void setZeroes(vector&l…
5.LC 零矩阵(中等)

面试题 01.08. 零矩阵 - 力扣(LeetCode)

思想:

法一:
利用两个集合分别储存要清0的行和列索引
另外两种原地优化空间的做法暂时不是目前刷题目标,故不考虑

代码

c++:

class Solution {
public:void setZeroes(vector<vector<int>>& matrix) {set<int> hang;set<int> lie;int n = matrix.size(), m = matrix[0].size();for (int i = 0; i < n; ++i) {for (int j = 0; j < m; ++j) {if (matrix[i][j] == 0) {hang.insert(i);lie.insert(j);}}}for (const auto& x : hang) {for (int j = 0; j < m; ++j) {matrix[x][j] = 0;}}for (const auto& x : lie) {for (int i = 0; i < n; ++i) {matrix[i][x] = 0;}}}
};

python:

class Solution:def setZeroes(self, matrix: List[List[int]]) -> None:"""Do not return anything, modify matrix in-place instead."""hang = set()lie = set()n, m = len(matrix), len(matrix[0])for i in range(n):for j in range(m):if matrix[i][j] == 0:hang.add(i)lie.add(j)for x in hang:for j in range(m):matrix[x][j] = 0for x in lie:for i in range(n):matrix[i][x] = 0
相似题

73. 矩阵置零 - 力扣(LeetCode)

6.LC 对角线遍历(中等,学习)

498. 对角线遍历 - 力扣(LeetCode)

思想:

1.n行m列矩阵,因为是按照对角线遍历,但是分析可得有两种对角线遍历方式,从左下到右上和从右上到左下,是由第i条对角线的奇偶决定的,所以按照对角线遍历, i ∈ [ 0 , n + m − 1 ) i \in [0,n+m-1) i[0,n+m1)
2.对于偶数对角线,是从左下到右上的遍历顺序,但又会出现遍历初始位置不同的情况,故再分类

  • i<n,说明在左边界,初始位置(i,0)
  • i>=n,说明在下边界,初始位置(n-1,i-(n-1))即(n-1,i-n+1)
    3.奇数对角线,是从右上到左下的遍历顺序,对偶式即可
  • i<m,说明在上边界,初始位置(0,i)
  • i>=m,说明在右边界,初始位置(i-m+1,m-1)
代码

c++:

class Solution {
public:vector<int> findDiagonalOrder(vector<vector<int>>& mat) {vector<int> res;int n = mat.size(), m = mat[0].size();for (int i = 0; i < n + m - 1; ++i) {// 右上到左下if (i % 2) {int x = i < m ? 0 : i - m + 1;int y = i < m ? i : m - 1;while (x < n && y >= 0) {res.emplace_back(mat[x][y]);x++;y--;}}// 左下到右上else {int x = i < n ? i : n - 1;int y = i < n ? 0 : i - n + 1;while (y < m && x >= 0) {res.emplace_back(mat[x][y]);x--;y++;}}}return res;}
};

python:

class Solution:def findDiagonalOrder(self, mat: List[List[int]]) -> List[int]:n, m = len(mat), len(mat[0])res = []for i in range(n + m - 1):if i % 2 == 1:x = 0 if i < m else i - m + 1y = i if i < m else m - 1while x < n and y >= 0:res.append(mat[x][y])x += 1y -= 1else:y = 0 if i < n else i - n + 1x = i if i < n else n - 1while y < m and x >= 0:res.append(mat[x][y])y += 1x -= 1return resclass Solution:def findDiagonalOrder(self, mat: List[List[int]]) -> List[int]:n,m=len(mat),len(mat[0])res=[]for i in range(n+m-1):if i%2==1:x=0 if i<m else i-m+1y=i if i<m else m-1while x<n and y>=0:res.append(mat[x][y])x+=1y-=1else:y=0 if i<n else i-n+1x=i if i<n else n-1while y<m and x>=0:res.append(mat[x][y])y+=1x-=1return res

1.没有三目运算符,要写成x=0 if i<m else i-m+1
2.没有++运算符,要写成x+=1

http://www.dtcms.com/wzjs/381692.html

相关文章:

  • 平台商城网站开发哈尔滨seo关键词
  • 商城网站功能视频号最新动作
  • 廊坊cms建站模板整合营销传播的明显特征是
  • av女优网站建设宣传企排排官网
  • 嘉兴营销型网站建设seo排名技巧
  • 济源市工程建设监理所网站培训网站制作
  • 使用html5做语音标注网站品牌营销理论
  • 淘宝客网站如何做SEO完整企业网站模板
  • 单页网站设计制作深圳网络推广引流
  • seo优化网站建设公司搜狗收录提交
  • 网站301做排名全国最新疫情最新消息
  • 如何再工商局网站做设备抵押seo和sem是什么意思啊
  • 全国建设工程信息网站广点通
  • 做软件赚钱还是做网站赚钱网络营销有哪些手段
  • 做网站公司宁波上市torrentkitty磁力搜索引擎
  • 奥林匹克做校服的网站福州seo经理招聘
  • 哪个网站做房子团购图片搜索识图入口
  • 企业有域名怎么做网站网站网络推广优化
  • 哪里可以做网站优化免费发布活动的平台
  • 网站开发主要流程青岛网站关键词优化公司
  • 睢宁做网站公司推广普通话的宣传标语
  • 国内做优秀的农业信息网站网站优化方式有哪些
  • 网站开发采集工具新闻头条今日要闻10条
  • 网站开发与软件开发的区别新产品推广
  • 营销网站建设专业公司临沂seo推广
  • 事业单位网站建设注销情况说明适合发朋友圈的营销广告
  • 重庆深蓝科技网站开发营销模式方案
  • 宁波市高新区建设局网站各大搜索引擎网址
  • 南昌哪里有网站建设百度首页登录
  • 网站建设维护单选题今日新闻头条热点