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

咋样做网站网站托管服务

咋样做网站,网站托管服务,开店装修话做那个网站找工人,企业如何对自己的网站进行建设文章目录前言03. 数组中重复的数字04. 二维数组中的查找05. 替换空格结语前言 #x1f603; 大家好#xff0c;我是writer桑#xff0c;这是自己整理的 C# 做题记录#xff0c;方便自己学习的同时分享出来#xff0c;感谢支持。 03. 数组中重复的数字 题目描述#xff1… 文章目录前言03. 数组中重复的数字04. 二维数组中的查找05. 替换空格结语前言 大家好我是writer桑这是自己整理的 C# 做题记录方便自己学习的同时分享出来感谢支持。 03. 数组中重复的数字 题目描述 找出数组中重复的数字。在一个长度为 n 的数组 nums 里的所有数字都在 0n-1 的范围内。数组中某些数字是重复的但不知道有几个数字重复了也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。 示例 输入 [2, 3, 1, 0, 2, 5, 3] 输出2 或 3 代码实现 public class Solution {public int FindRepeatNumber(int[] nums){HashSetint set new HashSetint { }; // 声明一个空的哈希表 foreach (int num in nums){if (set.Contains(num)) // 重复包含直接返回 return num;elseset.Add(num); // 无包含则添加 }return 0;} }思路分析 首先创建一个容器遍历数组中的每个数字并检查容器中有无这个数字 如果没有则直接放入元素 如果有则证明这个元素是重复的可直接返回。这里的容器推荐使用哈希表HashSet 因为哈希表的查找效率很高可以很好的提高整个算法的效率。 代码实现2 public class Solution {public int FindRepeatNumber(int[] nums) {Array.Sort(nums); // 循环遍历for (int i 1; i nums.Length; i) // 对数组进行排序 {if (nums[i] nums[i - 1])return nums[i];}return 0; } }思路分析 对数组进行排序for 循环从第二个元素开始遍历数组如果与前一个元素相等则可以证明该元素是重复的。因为需要多执行数组排序这一步所以性能没有第一种解法高推荐第一种解法。 04. 二维数组中的查找 题目描述 在一个 n * m 的二维数组中每一行都按照从左到右 非递减 的顺序排序每一列都按照从上到下 非递减 的顺序排序。请完成一个高效的函数输入这样的一个二维数组和一个整数判断数组中是否含有该整数。 示例 现有矩阵 matrix 如下 [    [1, 4, 7, 11, 15],    [2, 5, 8, 12, 19],    [3, 6, 9, 16, 22],    [10, 13, 14, 17, 24],    [18, 21, 23, 26, 30] ] 给定 target 5返回 true。 给定 target 20返回 false。 代码实现 public class Solution {public bool FindNumberIn2DArray(int[][] matrix, int target) {if (matrix.Length 0 || matrix null) // 判断是否为空 return false; int i matrix.Length - 1;int j 0;while (i 0 j matrix[0].Length){if (matrix[i][j] target)i--;else if (matrix[i][j] target)j;elsereturn true;}return false; } }思路分析 将矩阵逆时针旋转 45° 并展开可以发现类似于二叉搜索树 那么从根节点开始搜索时遇到比 target 大的元素就向左反之则向右以此来找到目标值 target 。需要事先判断 matrix 是否为空为空直接返回 false 。根据二叉搜索树的特性选用矩阵的左下角的元素作为标志数 flag若 flag target 则 target 一定在 flag 所在 行的上方, 若 flag target 则 target 一定在 flag 所在 列的右方以此类推直到找到目标数 target 。算法本身比较好理解难点在于根据题目的描述找到突破口。 代码实现2 public class Solution {public bool FindNumberIn2DArray(int[][] matrix, int target) {foreach (int[] arr in matrix){if(arr.Contains(target)) // 包含直接返回true{return true; }}return false; } }思路分析 简单的循环输出逐个数组进行判断有无包含目标数有则直接返回 true 。当循环结束时也即表示没有该目标数返回 false 。对比第一种解法代码量更少 但是因为每次都需要逐个遍历数组所以性能较低推荐第一种解法。 05. 替换空格 题目实现 请实现一个函数把字符串 s 中的每个空格替换成%20。 示例 输入s “We are happy.” 输出“We%20are%20happy.” 代码实现 public class Solution {public string ReplaceSpace(string s) {return string.Join(%20,s.Split( )); } }思路分析 使用 Split 方法指定空格 ’ ’ 进行分割再利用 Join 方法指定 “%20” 进行连接 然后直接返回即可。这种解法很容易想到而且代码量很少、很简洁一行代码搞定。 代码实现2 public class Solution {public string ReplaceSpace(string s) {StringBuilder res new StringBuilder(); // 声明可变字符串foreach(var c in s) // 循环遍历 {if(c )res.Append(%20);else res.Append(c); }return res.ToString(); } }思路分析 声明可变字符串 res 用于存放返回结果for 循环遍历字符串 s 依次判断字符元素 如果为空格 ’ ’ 则替换为%20放入 res , 如果不为空格则直接放入 res 中。循环结束则直接将 res 转换为字符串类型返回即可。与第一种解法相比这种解法更常见代码量较多两者在性能上差不多。 结语 以上就是本次的做题记录啦希望大家看完有所收获。同时希望大家多多支持你们的支持就是笔者学习最大的动力
http://www.w-s-a.com/news/386671/

相关文章:

  • dede网站 地图什么做有没有做黑市网站
  • 做网站参考文献域名如何做网站
  • 怎么选择网站开发英文网站建设用途
  • 怎样做电子商务网站织梦生成手机网站
  • 公司网站建设选什么服务器网站里怎样添加关键词
  • 深圳建设局网站深业中城绿化项目营销型网站开发流程包括
  • 找销售的网站九江市建设项目服务中心
  • 东原ARC网站建设公司合肥seo网站推广外包
  • 那个网站是做房产中介的网站制作软件小学
  • 做网页怎么建站点视频解析网站
  • 做网站的系统设计网站设计论文前言
  • 做外贸网站多久更新汕头市建设局网站首页
  • 如何建设专业化的网站手机管理网站模板
  • 花生壳做网站如何用腾讯云做网站
  • 搭建集团网站开发app需要哪些软件
  • 网站建设 中企动力福州阀门wordpress 多说评论
  • php网站集成支付宝接口下载免费网络软件
  • 卡盟网站是怎么建设的用花生壳做网站速度可以吗
  • 杭州物联网前十名公司优秀seo平台
  • 网新中英企业网站管理系统wordpress 登录 缓存
  • wordpress模板建站教程wordpress添加广告位手机自适应
  • h5游戏平台入口优化是什么梗
  • 建设银行对公网站打不开网络推广活动方案主题和思路
  • 茶叶网站开发目的和意义网页设计需要考什么证
  • 高端企业网站建设公司怎么做实用性建设网站都需要哪些
  • 网站备案必须要幕布吗易企秀网站怎么做轮播图
  • 南昌网站排名优化四线城市网站建设方向及营利点
  • 做网站需要钱吗unity 做网站
  • 呼伦贝尔市规划建设局网站wordpress怎么考别人的
  • 免备案自助建站网站成都神速建站