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

专业的个人网站建设哪家国外域名免费注册

专业的个人网站建设哪家,国外域名免费注册,如何做qq钓鱼网站,wordpress博客xiuleetcode 1089. 复写零 leetcode 1089. 复写零 | 简单难度1. 题目详情1. 原题链接2. 基础框架 2. 解题思路1. 题目分析2. 算法原理3. 时间复杂度 3. 代码实现4. 知识与收获 leetcode 1089. 复写零 | 简单难度 1. 题目详情 给你一个长度固定的整数数组 arr #xff0c;请你将… leetcode 1089. 复写零 leetcode 1089. 复写零 | 简单难度1. 题目详情1. 原题链接2. 基础框架 2. 解题思路1. 题目分析2. 算法原理3. 时间复杂度 3. 代码实现4. 知识与收获 leetcode 1089. 复写零 | 简单难度 1. 题目详情 给你一个长度固定的整数数组 arr 请你将该数组中出现的每个零都复写一遍并将其余的元素向右平移。 注意请不要在超过该数组长度的位置写入元素。请对输入的数组 就地 进行上述修改不要从函数返回任何东西。 示例 1 输入arr [1,0,2,3,0,4,5,0] 输出[1,0,0,2,3,0,0,4] 解释调用函数后输入的数组将被修改为[1,0,0,2,3,0,0,4] 示例 2 输入arr [1,2,3] 输出[1,2,3] 解释调用函数后输入的数组将被修改为[1,2,3] 提示 1 arr.length 104 0 arr[i] 9 1. 原题链接 leetcode 1089. 复写零 2. 基础框架 ● Cpp代码框架 class Solution { public:void duplicateZeros(vectorint arr) {} };2. 解题思路 1. 题目分析 ( 1 ) (1) (1) 本题要求 对数组arr的0元素复写到下一个位置且其余元素依次后移一位超过数组长度的元素会被丢弃。 ( 2 ) (2) (2) 要求空间复杂度 O ( 1 ) O(1) O(1)对数组原地进行操作。 2. 算法原理 ( 1 ) (1) (1) 一个好想的思路就是忽略题目对空间复杂度 O ( 1 ) O(1) O(1)的要求额外创建一个长度为假设数组arr长度为nn的数组nums遍历arr数组如果当前元素等于0就2次写入nusm否则当前元素1次写入nums;直到新数组nums被写满就停止此时nums中就保存着复写的结果。 ( 2 ) (2) (2) 好的现在让我们尝试不创建额外数组而是原地修改arr。 使用快慢双指针算法定义快指针dest指向复写后的位置慢指针cur指向复写前的位置 ( 3 ) (3) (3) 如果直接从前往后进行复写操作明显是行不通的因为arr[cur]0时dest走两步而cur一直走一步会出现cur未遍历到的元素被覆盖的情况 ( 4 ) (4) (4) 只能考虑从后往前写。那么如何确定dest和cur的初始位置呢 首先明确一点dest一定不慢于cur故初始的前后位置情况一定是dest与cur相等或dest在cur之后。 完全模拟正着复写0操作直到cur遍历完整个数组arr此时dest大概率是处于越界位置的。 只模拟到有效位置 ( 5 ) (5) (5) 处理特殊情况下的越界 ( 6 ) (6) (6) 倒着实际执行复写操作 从cur所指位置开始向前遍历 如果nums[cur]0则nums[dest]和nums[dest-1]位置均被设置为0之后dest-2 反之nums[cur]!0则nums[dest]位置被设置为nums[cur]的值之后dest-- 每次判断之后cur都向前移动即cur--。 3. 时间复杂度 O ( n ) O(n) O(n) 第一步模拟复写0时遍历了一遍数组第三步从cur位置往前复写时也遍历了一遍数组故时间复杂度是 O ( n ) O(n) O(n) 3. 代码实现 class Solution { public:void duplicateZeros(vectorint arr) {int dest -1, cur 0;int n arr.size();// 正着模拟复写确定最后复写位置while(dest n - 1){if(arr[cur] 0){dest2;}else{dest;}cur;}// 循环结束cur指向了最后复写位置的下一个位置需要回退1// dest指向了复写后新数组的最后一个位置cur--;// 越界控制与调整此种情况是cur指向0时destn-2// 此时dest模拟复写dest2后为destn之后循环结束。/* 特殊处理这种情况此时是复写0但只有前1个0有效后一个0越界了。为使下文正常复写调整复写位置真正复写时从最后复写位置的前一个位置开始让dest-2cur--并直接对最后复写位置特殊复写*/if(dest n){dest - 2;cur - 1;arr[n - 1] 0;}// 倒着复写while(cur 0){if(arr[cur] 0){arr[dest--] 0;arr[dest--] 0;}else arr[dest--] arr[cur];cur--;}} };4. 知识与收获 ( 1 ) (1) (1) 有时候正面无法突破问题时反面是一个很好的突破口。 T h e The The E n d End End
http://www.w-s-a.com/news/374767/

相关文章:

  • 如何做com的网站网站建设投标书模板
  • 郑州网络营销网站优化网站技术方案怎么写
  • 济南市住房和城乡建设局网站wordpress mnews主题
  • ios开发网站app网站建设企业有哪些方面
  • 网站主页 优帮云深圳代做网站后台
  • app 与网站网站建设要做什么
  • 厦门国外网站建设公司郑州核酸点推vip服务
  • 免费网线seo外链怎么做
  • 宽带技术网网站wordpress widget hook
  • 山西省住房和城乡建设厅网站报名wordpress添加标签插件
  • 网站怎么自己做外贸网站案例
  • 做网站的优势公司网站怎么做站外链接
  • 海城网站制作建设精准营销的营销方式
  • 北京短视频拍摄公司重庆网站seo推广公司
  • 广州免费推广网站建设4399网页游戏大全
  • 网站的构架与组成建站公司兴田德润
  • php网站部署步骤邯郸哪有做网站的
  • 做设计什么设计比较好的网站南充市住房和城乡建设局考试网站
  • 郑州做系统集成的公司网站龙岩
  • 厦门SEO_厦门网站建设网络营销课程视频
  • vs 2015 网站开发开网店在线咨询
  • 前端如何优化网站性能大学学校类网站设计
  • 中国铁路建设投资公司网站熊学军中国it外包公司排名前50
  • 房产网站的建设广州推广排名
  • 湟源县网站建设wordpress删除未分类
  • 营销型网站开发推广厦门百度seo公司
  • 遵义网站开发培训上海中高风险地区名单最新
  • 禹州市门户网站建设做网站可以申请个体户么
  • 大良营销网站建设效果彩票网站搭建 做网站
  • 做网站的公司为什么人少了在中国如何推广外贸平台