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

做电影网站犯罪吗温州哪里有网站优化

做电影网站犯罪吗,温州哪里有网站优化,建网站要多长时间,大型网络手游游戏排行榜11. 26. 删除有序数组中的重复项(简单,双指针) 26. 删除有序数组中的重复项 - 力扣(LeetCode) 思想: 1.我的思想: 双指针遍历集合储存已有元素 2.官方思想: 题目条件有序数组删除重复元素,所以重复元素都是连续存在…
11. 26. 删除有序数组中的重复项(简单,双指针)

26. 删除有序数组中的重复项 - 力扣(LeetCode)

思想:

1.我的思想:
双指针遍历+集合储存已有元素
2.官方思想:
题目条件有序数组删除重复元素,所以重复元素都是连续存在
同向快慢指针,慢指针指向下一个赋值位置,快指针遍历寻找不重复元素,即fast[i]!=fast[i-1]时,找到不重复元素,赋值给slow位置,slow++
最终[0,slow)为不重复元素区域,长度为slow
初始条件判断:数组元素为0直接返回0,让fast[i-1]有意义

代码

我的:
c++:

class Solution {
public:int removeDuplicates(vector<int>& nums) {set<int> s;int n = nums.size();int left = 0;for (int right = 0; right < n; ++right) {if (s.find(nums[right]) == s.end()) {nums[left] = nums[right];left++;s.insert(nums[right]);}}return left;}
};

python:

class Solution:def removeDuplicates(self, nums: List[int]) -> int:s = set()n = len(nums)left, right = 0, 0for right in range(n):if nums[right] not in s:s.add(nums[right])nums[left] = nums[right]left += 1return left

官方:
c++:

class Solution {
public:int removeDuplicates(vector<int>& nums) {int n = nums.size();if (n == 0)return 0;int slow = 1;for (int fast = 1; fast < n; ++fast) {if (nums[fast] != nums[fast - 1]) {nums[slow] = nums[fast];slow++;}}return slow;}
};

python:

class Solution:def removeDuplicates(self, nums: List[int]) -> int:n = len(nums)if n == 0:return 0slow = 1for fast in range(1, n):if nums[fast] != nums[fast - 1]:nums[slow] = nums[fast]slow += 1return slow
12. 283. 移动零(简单,双指针)

283. 移动零 - 力扣(LeetCode)

思想

1.快慢双指针,10 27.移除元素 val=0时的特殊情况,且不再是赋值,而是交换

代码

c++:

class Solution {
public:void moveZeroes(vector<int>& nums) {int n = nums.size();int slow = 0;for (int fast = 0; fast < n; ++fast) {if (nums[fast] != 0) {swap(nums[slow], nums[fast]);slow++;}}}
};

python:

class Solution:def moveZeroes(self, nums: List[int]) -> None:"""Do not return anything, modify nums in-place instead."""n = len(nums)slow = 0for fast in range(n):if nums[fast] != 0:nums[slow], nums[fast] = nums[fast], nums[slow]slow += 1
13. 844. 比较含退格的字符串(简单,学习,栈,双指针)

844. 比较含退格的字符串 - 力扣(LeetCode)

思想

1.法一(栈):
最直观想到遇到’#'号回退,来模拟这一过程,就是,因为是字符串处理,可以直接用字符串当栈
注意:栈要弹出元素时立刻想到判断栈不为空
2.法二(双指针):
(1)一个字符是否会被删掉取决于后面的字符,与前面的字符无关,所以逆序遍历可以先遇到#号字符从而确定前面的字符是否要被删掉
(2)目标是比较不会被删掉的字符,所以用两个同向逆序指针,i表示当前要比较的不会被删掉的字符,skip记录当前遇到的#号字符数量,即要删除的字符数量,从而确定i的位置,逻辑如下:

  • 遇到#号字符,skip++,i–
  • 未遇到#号字符
    • skip>0,删除当前字符,i–
    • skip=0,退出寻找i的位置循环
      而总体的遍历指针是i,遍历范围[0,n),寻找i的位置后要判断是否在范围内
代码

法一
c++

class Solution {
public:bool backspaceCompare(string s, string t) {if (build(s) == build(t))return true;return false;}string build(string str) {string res;for (char ch : str) {if (ch != '#')res.push_back(ch);else if (!res.empty())res.pop_back();}return res;}
};

python:

class Solution:def backspaceCompare(self, s: str, t: str) -> bool:if self.build(s) == self.build(t):return Truereturn Falsedef build(self, s: str) -> str:res = ""for ch in s:if ch != "#":res += chelif s:res = res[:-1]return res

1.调用函数要用self.
2.字符串是不可变对象,要用+=
3.删除最后一个字符为[:-1],因为最后一个end取不到
法二:
c++:

class Solution {
public:bool backspaceCompare(string s, string t) {int i = s.size() - 1, j = t.size() - 1;while (i >= 0 ||j >= 0) { // 一个为空串时,另一个可能前面还有#号可能变成空串int skipS = 0, skipT = 0;while (i >= 0) {if (s[i] == '#') {skipS++;i--;} else if (skipS > 0) {skipS--;i--;} else {break;}}while (j >= 0) {if (t[j] == '#') {skipT++;j--;} else if (skipT > 0) {skipT--;j--;} else {break;}}if (i >= 0 && j >= 0) {if (s[i] != t[j]) {return false;}} else {if (i >= 0 || j >= 0) {return false;}}i--;j--;}return true;}
};

python:

class Solution:def backspaceCompare(self, s: str, t: str) -> bool:i, j = len(s) - 1, len(t) - 1while i >= 0 or j >= 0:skipS, skipT = 0, 0while i >= 0:if s[i] == "#":skipS += 1i -= 1elif skipS > 0:skipS -= 1i -= 1else:breakwhile j >= 0:if t[j] == "#":skipT += 1j -= 1elif skipT > 0:skipT -= 1j -= 1else:breakif i >= 0 and j >= 0:if s[i] != t[j]:return Falseelse:if i >= 0 or j >= 0:return Falsei -= 1j -= 1return True
http://www.dtcms.com/wzjs/532973.html

相关文章:

  • 银川网站推广方式济南 网站建设那家好
  • 建设治安总队网站目的2015网站设计趋势
  • 钢丝高频退火设备网站建设可以用自己电脑做网站吗
  • 辽宁省朝阳网站建设得力文具网站建设策划书
  • 做微网站 主机 域名网站建设费用明细湖南岚鸿
  • 建站公司联系电话企业网站建设需了解什么
  • 百度和阿里哪个厉害做网站我想做一个网站
  • 浙江省一建建设集团网站首页网站建设-好发信息网
  • 网站的行为怎么做网站页面设计主要包括
  • 建设一个商城网站要多少钱wordpress找不到自定义栏目
  • 平阳网站开发兰州网站seo分析
  • 牡丹江建设行业协会网站怎么做网站的登录界面
  • 学ps可以做网站策划吗安徽设计网站建设
  • 青海企业网站开发定制做电商自建网站怎样
  • 泰州市建设工程招标网汕头网站关键词优化教程
  • 一个企业网站多少钱网站导航样式
  • 黄岛区建设局网站wordpress 搜索框
  • 用于网站建设的费用怎么备注网站建设需要矢量文件
  • 网站推广描述html5简单网页源代码
  • 网站服务器搭建适合机械网站的wordpress主题模板
  • 专业网站优化软件手机网站专题
  • 农业局网站建设实施方案做彩票网站代理违法吗
  • 网站图片轮播怎么弄石家庄做标书的网站
  • 做网站用php如何学习百度账号注册平台
  • 虚拟币网站开发制作企业查询天眼查
  • 南京网站制作公司招聘桂林八里街论坛
  • 上传图片的网站要怎么做如何上传文件到网站
  • 网站支付模块wordpress 企业主题下载
  • 湖北建设厅网站安全员名单宁波网站建设推广平台
  • 好用的wordpress兰州seo推广