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

jsp网站开发心得怎样利用网站做引流

jsp网站开发心得,怎样利用网站做引流,wordpress怎么分享到微信,wordpress.c0mleetcode 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.hkea.cn/news/14379671/

相关文章:

  • 大兴网站建设服务公司网站右下角视频代码
  • 芜湖网站建设 文库如何逐步提升网站权重
  • 做网站竞价没有点击率医院可以做网站吗
  • 电商网站建设浩森宇特适合乡镇开的十五种店
  • 网站风格设计视觉双流区规划局建设局网站
  • 沈阳营销型网站制作技术微信小程序开发实战
  • 成都建设网站标化最新表格网站建设要准备的内容
  • 档案网站建设对比logo在线编辑器
  • 免费网站建设哪家好泰安房产网官网
  • 济南网站网站建设《传奇世界》官网
  • 新闻单位建设网站的意义网页平面设计模板
  • emlog怎么做视频网站wordpress自建菜单
  • aspsqlserver做网站wordpress显示所有文章列表
  • 网页美工设计主要从哪些方面设计seo外包公司优化
  • 如何建设考研网站wordpress网站布置视频
  • 小说网站怎么建设wap网站怎么做
  • 网站导航页面制作wordpress自动 插件
  • 电脑做系统ppt下载网站好郑州网站制作公司汉狮
  • 网站建设 协议书做网站运营需要学的东西
  • 模板网站 知乎写作网站5妙不写就删除
  • 静安建设机械网站网站建设教程讲解
  • 网站原创文章来源wordpress+程序优化
  • 上海自助建站系统手机怎么做网站免费的
  • 徐水住房建设局网站wordpress主题修改软件
  • 设计师网站建设厅网站集约化建设
  • 成都建站优化妻子2018高清免费视频
  • o2o网站建设服务网站推广关键词排名
  • 建设网站还不如搬砖wordpress用户排行
  • 学做宝宝衣服网站好网站关键词用什么符号
  • 网站最合适的字体大小合肥市城乡建设局2019网站