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

商务网站开发的基本流程网站搜索引擎优化诊断

商务网站开发的基本流程,网站搜索引擎优化诊断,做金融的网站有哪些,徐州市城乡和住房建设局网站题目 给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返回移除后数组的新长度。 不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并 原地 修改输入数组。 元素的顺序可以改变。你不需要考虑数组中超出新长度…

题目

给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返回移除后数组的新长度。
不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并 原地 修改输入数组。
元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。

说明:

为什么返回数值是整数,但输出的答案是数组呢?
请注意,输入数组是以「引用」方式传递的,这意味着在函数里修改输入数组对于调用者是可见的。
你可以想象内部操作如下:
// nums 是以“引用”方式传递的。也就是说,不对实参作任何拷贝
int len = removeElement(nums, val);
// 在函数里修改输入数组对于调用者是可见的。
// 根据你的函数返回的长度, 它会打印出数组中 该长度范围内 的所有元素。
for (int i = 0; i < len; i++) {
print(nums[i]);
}

示例 1:

输入:nums = [3,2,2,3], val = 3
输出:2, nums = [2,2]
解释:函数应该返回新的长度 2, 并且 nums 中的前两个元素均为 2。你不需要考虑数组中超出新长度后面的元素。例如,函数返回的新长度为 2 ,而 nums = [2,2,3,3] 或 nums = [2,2,0,0],也会被视作正确答案。

示例 2:

输入:nums = [0,1,2,2,3,0,4,2], val = 2
输出:5, nums = [0,1,4,0,3]
解释:函数应该返回新的长度 5, 并且 nums 中的前五个元素为 0, 1, 3, 0, 4。注意这五个元素可为任意顺序。你不需要考虑数组中超出新长度后面的元素。

分析

题目要求原地移出等于某个值的元素且不使用额外的空间,那我们找到等于该值的元素有多少个,然后用其他元素覆盖不就行了,具体怎么实现呢?上代码:
方法一:
逐个向前覆盖,当找到第一个要覆盖的元素,后面元素在每次循环时向前移动一个,当找到两个要覆盖的元素,后面元素在每次循环时向前移动两个,以此类推
C语言实现

// 时间复杂度:O(n)
// 空间复杂度:O(1)
int removeElement(int* nums, int numsSize, int val){int i;int count=0;for(i=0;i<numsSize;i++){nums[i-count]=nums[i];if(nums[i]==val){count++;}}return numsSize-count;
}

方法二:
其实相当于定义了两个指针,一个指向最前面,一个指向最后面,从前面指针指向的元素开始循环,如果不是要覆盖的元素,前面那个指针前进一格,如果是要覆盖的元素,就跟后面那个指针指向的元素进行交换,交换之后,后面那个指针向后退一格,直到两个指针相遇
C语言实现

// 时间复杂度:O(n)
// 空间复杂度:O(1)
int removeElement(int* nums, int numsSize, int val){int right=numsSize-1;int left=0;while(left<=right){if(nums[left]==val){nums[left]=nums[right];right--;}else{left++;}}return right+1;
}

方法三:
双指针法(快慢指针法): 通过一个快指针和慢指针在一个for循环下完成两个for循环的工作。
快指针:寻找新数组的元素 ,新数组就是不含有目标元素的数组
慢指针:指向更新 新数组下标的位置
c++实现

// 时间复杂度:O(n)
// 空间复杂度:O(1)
class Solution {
public:int removeElement(vector<int>& nums, int val) {int slowIndex = 0;for (int fastIndex = 0; fastIndex < nums.size(); fastIndex++) {if (val != nums[fastIndex]) {nums[slowIndex++] = nums[fastIndex];}}return slowIndex;}
};
http://www.shuangfujiaoyu.com/news/3617.html

相关文章:

  • 免费做网站软件上海最新政策
  • 衡阳手机网站建设b2b网站大全免费推广
  • 遨游网站建设女性广告
  • 如何做网站 百度动态网站设计毕业论文
  • 在哪里做企业网站seo和sem的区别是什么
  • 湖南手机网站建设公司win10优化软件哪个好
  • wordpress b站插件济南seo优化外包
  • 北京著名的网站制作公司实体店营销方案
  • 响应式网站实例百度手机助手下载2021新版
  • 网站备案的是空间还是域名网站建设关键词排名
  • 医疗电子的网站建设5000人朋友圈推广多少钱
  • 公司外包seo外包优化公司
  • 宁波网站公司哪里好阿里云免费建站
  • 优惠活动制作网站在线客服
  • 郑州做网站建设公司排名百度下载安装官方下载
  • 企业官网网站模板营销网络是什么
  • 移民网站用什么系统做网站好中文域名注册
  • 写出网站开发的基本流程宣传软文范例
  • 厦门网站建站苏州优化seo
  • 网站开发与软件开发软文写作案例
  • 如何做网站内部优化餐饮培训
  • 建设部网站核对编号纯手工seo公司
  • 网页设计表单注册代码seo包年优化平台
  • 网站做好后怎么更新内容网络营销培训班
  • 网站页眉尺寸防城港网站seo
  • wordpress 微言插件最新seo黑帽技术工具软件
  • 免费下载app软件下载安装上海比较大的优化公司
  • 昆明网站建设王道下拉棒网站建设杭州
  • 文登区住房和城乡建设局网站seo教学网seo
  • html做高逼格网站电脑培训