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

做网站需要怎么分工网站搜索

做网站需要怎么分工,网站搜索,济南网站建设内容,内江市建设信息网站题目来源:力扣 此解法是在力扣官网上找到的 原作者:Storm 链接:1424. 对角线遍历 II - 力扣(LeetCode) 加上了自己的理解与分析便于理解代码 // 对角线遍历2// 给你一个列表 nums ,里面每一个元素…

题目来源:力扣

此解法是在力扣官网上找到的

原作者:Storm

链接:1424. 对角线遍历 II - 力扣(LeetCode)

加上了自己的理解与分析便于理解代码

//    对角线遍历2//    给你一个列表 nums ,里面每一个元素都是一个整数列表。//    请你依照下面各图的规则,按顺序返回 nums 中对角线上的整数。​//    每一个子列表代表一行,不同行的长度可能不同public static int[] findDiagonalOrder(List<List<Integer>> nums) {List<int[]> list = new ArrayList<int[]>();int rows = nums.size();for (int i = 0; i < rows; i++) {List<Integer> rowList = nums.get(i);int cols = rowList.size();for (int j = 0; j < cols; j++) {int num = rowList.get(j);list.add(new int[]{i + j, j, num});}}Collections.sort(list, (a, b) -> {if (a[0] != b[0]) {return a[0] - b[0];} else {return a[1] - b[1];}});int size = list.size();int[] order = new int[size];for (int i = 0; i < size; i++) {order[i] = list.get(i)[2];}return order;}

代码详细解释

1. 定义类和方法
 class Solution {public int[] findDiagonalOrder(List<List<Integer>> nums) {
  • 定义了一个名为 Solution 的类。

  • 定义了一个公共方法 findDiagonalOrder,它接收一个嵌套列表 nums 作为参数,并返回一个整数数组。

2. 创建存储元素信息的列表
List<int[]> list = new ArrayList<int[]>();int rows = nums.size();
  • 创建了一个 List<int[]> 类型的 list,用于存储每个元素的信息。每个元素信息用一个长度为 3 的整数数组表示,分别存储 i + jj 和元素值。(用于后面排序)

  • rows 变量存储了嵌套列表的行数。

3. 遍历嵌套列表
 for (int i = 0; i < rows; i++) {List<Integer> rowList = nums.get(i);int cols = rowList.size();for (int j = 0; j < cols; j++) {int num = rowList.get(j);list.add(new int[]{i + j, j, num});}}
  • 外层循环遍历每一行,获取当前行的子列表 rowList 以及当前行的列数 cols

  • 内层循环遍历当前行的每一列,获取当前元素 num,并将 [i + j, j, num] 存储到 list 中。

4. 对元素信息列表进行排序(重点排序)
Collections.sort(list, (a, b) -> {if (a[0] != b[0]) {return a[0] - b[0];} else {return a[1] - b[1];}});
  • 使用 Collections.sort 方法对 list 进行排序。

  • 排序规则是:先比较元素的 i + j 值(即 a[0]b[0]),若不相等,则按照 i + j 从小到大排序;若相等,则比较列索引 j(即 a[1]b[1]),按照列索引从小到大排序。

5. 创建结果数组并存储排序后的元素
 int size = list.size();int[] order = new int[size];for (int i = 0; i < size; i++) {order[i] = list.get(i)[2];}
  • size 存储了 list 的大小,即元素的总数。

  • 创建一个长度为 size 的整数数组 order

  • 遍历 list,将每个元素信息数组中的第三个元素(即元素值)存储到 order 数组中。

6. 返回结果数组
 return order;
  • 返回存储排序后元素的数组 order

复杂度分析

  • 时间复杂度O(Nlog**N),其中 N 是嵌套列表中元素的总数。主要时间开销在于对 list 进行排序。

  • 空间复杂度O(N),主要空间开销在于存储元素信息的 list 和结果数组 order

有更好的解法,欢迎评论或私信

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

相关文章:

  • 做网站需要多长时间才能做好网站秒收录工具
  • WordPress评论楼层seo顾问服务 品达优化
  • 怎么自己的电脑做网站服务器seo搜索引擎优化实训总结
  • 域名都有哪些seo排名第一的企业
  • 美橙互联旗下网站线上宣传方式有哪些
  • 菏泽 兼职做网站网站建设制作过程
  • 木樨园网站建设百度资源搜索平台官网
  • 医疗保险网站开通建设恶意点击广告软件
  • 建设银行信用卡申请官方网站域名停靠
  • 点击图片是网站怎么做的百度关键词怎么做
  • 中国建设银行对公网站谷歌paypal官网
  • 有了网站源码怎么做app谈谈你对seo概念的理解
  • 如何做病毒式网站推广站内营销推广途径
  • 建设网站有哪些目的合肥网站排名提升
  • 自己做网站需要主机吗网络营销策划公司
  • 做网站可以设账户吗关键词优化包含
  • 河南住房和城乡建设厅门户网站学习软件
  • 彩票网站招代理广告怎么做全国疫情最新名单
  • tomcat做公司网站seo秘籍优化课程
  • 网站开发与设计期末考试兰州seo外包公司
  • 怎么制作网站视频教程如何免费注册一个网站
  • 郑州高端做网站百度安全中心
  • 网站建设管理经验如何做外贸网站的推广
  • 网站建设最好的公司seo站内优化最主要的是什么
  • html课程教学网站模板免费自制app软件
  • 南昌企业网站排名优化推广app网站
  • 软件开发app开发定制外包搜索引擎优化方法与技巧
  • 建网站资料网络广告策划书模板范文
  • 网站建设模拟实验报告国际大新闻最新消息
  • 网站开发简历seo推广哪家好