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

新县城乡规划建设局网站网站建设套餐报价方案

新县城乡规划建设局网站,网站建设套餐报价方案,诸城人才网招聘网,个人主页格式声明 该系列文章仅仅展示个人的解题思路和分析过程#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://wiki.neutronadmin.com/news/122147/

相关文章:

  • 网站动画效果用什么程序做的邯郸手机建站价格
  • vs2015网站开发教程wpf入可以做网站吗
  • 直接做的黄页视频网站国内知名的网站建设公司
  • 案例 网站工程公司会计账务处理
  • 网站建设公司果动c网站你懂我意思正能量免费软件
  • 上海最好的网站是什么成都百度推广和seo优化
  • 网站全屏代码asp 做网站的缺点
  • 福州帮人建网站公司网站设计公司圣辉友联
  • 福州+网站开发网站建设越秀
  • 互联网软件开发工资一般多少衡阳百度seo
  • 横沥镇做网站网咖活动营销方案
  • 城乡建设网站 资料员怎么修改网站的源代码
  • 网站建设范本制作头像的软件
  • 做网站比较好的公司网站上怎样做轮播图
  • 去中企动力上班怎么样杭州网站建设seo优化
  • 上海做网站的知名企业WordPress主题启用出现错误
  • 自己的主机做服务器网站如何备案星外网站开发
  • 湖南竞网科技有限公司南京seo公司
  • 网页设计实训报告美食主题做seo如何赚钱
  • 网站推广排名服务科技部政务服务平台
  • 周至县做网站淮南服装网站建设费用
  • 北京网站建站深圳宝安中心医院
  • 怎么做qq业务网站建网站多少钱一个平台
  • 湖南城乡住房建设厅网站网站建设可行性分析报告模板
  • 丹灶网站建设深圳装修公司口碑排名
  • 网站开发下载哪个同泰公司网站公司查询
  • 网站建设怎么链接表格大学生创新创业大赛报名入口
  • 深圳网站建设黄浦网络 骗子公司邮箱后缀正确的是以下
  • 招聘 网站建设表白网页在线生成制作源码
  • 建设部网站电话丽水微信网站建设公司