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

动态速写网站淘宝网站网页图片怎么做

动态速写网站,淘宝网站网页图片怎么做,湖南株洲静默,wordpress谁开发的声明 该系列文章仅仅展示个人的解题思路和分析过程#xff0c;并非一定是优质题解#xff0c;重要的是通过分析和解决问题能让我们逐渐熟练和成长#xff0c;从新手到大佬离不开一个磨练的过程#xff0c;加油#xff01; 原题链接 用对角线遍历矩阵https://leetcode.c…声明 该系列文章仅仅展示个人的解题思路和分析过程并非一定是优质题解重要的是通过分析和解决问题能让我们逐渐熟练和成长从新手到大佬离不开一个磨练的过程加油 原题链接 用对角线遍历矩阵https://leetcode.cn/leetbook/read/array-and-string/cuxq3/ 算法分析 图一 图二 图三 图四 由上述四个图可以总结得出以下八个结论  结论1k属于[0,a(max)b(max)]。 结论2每一层遍历行最多存在min(m,n)个矩阵索引对min(m,n)表示m和n二者中小的那一个值。 结论3a属于[0,m-1]b属于[0,n-1]。 结论4若k为偶数则以a为比较对象此时若ka(max)则当前遍历行的起始索引对为(k,0)反之则起始索引对为(a(max),k-a(max))。 结论5若k为奇数则以b为比较对象此时若kb(max)则当前遍历行的起始索引对位(0,k)反之则起始索引对为(k-b(max),b(max))。 结论6从当前遍历行的起始索引对开始若k为偶数则下一个索引对为(a-1,b1)反之下一个索引对为(a1,b-1)。 结论7遍历行的结束条件由该矩阵的遍历行最大索引对个数和a(min)、b(min)共同决定首先应判断当前遍历行访问的矩阵索引对个数是否达到了该矩阵的遍历行最大索引对个数若达到了则完成该遍历行的遍历否则判断下一个索引对(a,b)若a或b越界则表明完成该遍历行的遍历。 结论8整个矩阵遍历结束的条件是当前遍历的矩阵索引对的个数是m×n个。 代码示例C# public int[] FindDiagonalOrder(int[][] mat) {int m mat.Length;//矩阵的行数int n mat[0].Length;//矩阵的列数int[] result new int[m * n];//结果数组//a:索引对的a,b:索引对的b,k:ab,count:当前已遍历的矩阵索引对个数,minA:a的最小值//minB:b的最小值,index:结果数组中的索引指针int a, b, k 0, count 0, minA 0, minB 0, index 0;int maxA m - 1;//a的最大值int maxB n - 1;//b的最大值int maxIndexsCount m n ? m : n;//该矩阵中遍历行的矩阵索引对个数的最大值int lineIndexsCount;//遍历行当前已遍历的矩阵索引对个数while (count m * n){lineIndexsCount 0;//若k%2为0则表示k为偶数反之则为奇数if (k % 2 0){if (k maxA){a k;b 0;}else{a maxA;b k - maxA;}}else{if (k maxB){a 0;b k;}else{a k - maxB;b maxB;}}while (lineIndexsCount maxIndexsCount){//a或b越界则完成此次遍历行的遍历if ((a minA || a maxA) || (b minB || b maxB)) break;//记录结果result[index] mat[a][b];count;if (k % 2 0){a--;b;}else{a;b--;}}k;}return result; } 算法解说  按照原题的思路我们列举出了四种矩阵严格来说只有三种分别是矩阵行数大于列数、行数等于列数、行数小于列数而为了保证后续结论的真实性我们列举了两个行数等于列数的矩阵。 图中我们完成了四个矩阵的制定然后按照题目要求去遍历了四个矩阵并且将遍历的结果记录下来从行列定义上我们可以将矩阵构建在二维平面中从而为每一个元素设立一个唯一的坐标值在本题中我们把这个坐标值称为索引对。有了索引对我们可以进一步按照索引对两个数值之和对遍历结果进行分组在本题中我们把索引对两个数值之和相同的一组索引对称为遍历行为了简便后续将索引对两个数值之和称为索引对结果值。 将遍历行按照索引对结果值从小到大的顺序进行排列为了能够发现更多有用的结论我们把每一层遍历行的索引对结果值、结果值的奇偶性、索引对与k值的关系列举出来除此之外还需要列举出矩阵行列数以及索引对两个数值的取值范围至于为什么要去列举这些东西实际上还是通过尝试和思考就像上学时做数学题浏览题目之后列举出题目中给定的条件然后根据条件去解题。 这一步我们可以理解为进一步细化和剖析已知条件我们的目的是从已知条件中获取可靠的结论从而根据结论解决问题因此我们总结出了上文的八个结论。 那么已知结论后如何去编写代码呢本人是按照以下几个问题去解决的。 1.我们需要明白输入和输出是什么 2.我们需要定义哪些变量 3.函数主体是什么 4.某些过程的结束条件是什么 实际上就是将我们的八个结论构建为代码简单划分就是定义变量和逻辑主体定义变量就看结论中需要记录数据的描述逻辑主体就看结论中对于逻辑处理、结束条件的描述。 当然这样转换出来的代码比较粗糙所以后续还可以结合自己的编程知识再去优化自己的代码让它变得更加简洁精致。
http://www.hkea.cn/news/14378873/

相关文章:

  • 商务网站开发的工作任务用sql2000做网站
  • 做加盟网站赚钱吗房地产信息网新楼盘
  • 多说评论插件对网站优化网站免费正能量直接进入老狼
  • 惠州市+网站开发公司西安网站建设王永杰
  • 阿里云服务器windows系统网站搭建教程模板网站与定制开发网站的区别
  • 无锡网站设计公司排名威海做网站的
  • 联盟网站wordpress中间页跳转插件
  • 酒店做爰视频网站wordpress伪静态和静态
  • 电子商务网站建设的范围是什么意思申请网站官网
  • 做搜狗网站优化排给公司做网站费用
  • 高密营销型网站建设公司网络组建方案怎么写
  • 电子商务网站设计思路网页传奇怎么删除
  • 百度网盘pc端网页版苏州seo网站推广公司
  • 高级网站开发工信部静态网站开发 内容
  • 设计需求网站没有办公地点怎么注册自己的公司
  • 驻马店企业做网站可以免费注册的网站
  • 有哪个网站可以学做早餐吃的如何建个人微信公众号
  • 提供建立网站服务的公司中信建设有限责任公司发债公告
  • 公众号的微网站开发某旅行社网站建设规划书
  • 泉港报名网站建设需要上海上市公司100强
  • 那些域名可以做后缀做网站建网站不花钱免费建站
  • 公司网站怎么能被百度收录内网网站怎么建设
  • node 网站开发wordpress怎么调用api
  • 花卉网站源码app网站开发河 又
  • 个人网站备案 各省如何网上申请个人营业执照
  • 上海广告公司联系方式东莞宣布优化防疫措施
  • 河北省建设厅网站手机版世界500强中国企业名单
  • 网站购物车js代码怎么做jquery前端框架教程
  • 公司网站建设需求说明书河北公司网站开发
  • 怎样创建公司网站如何找外贸公司