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

每日算法刷题计划Day5 5.13:leetcode数组3道题,用时1h

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

相关文章:

  • mac 10.15.7 svn安装
  • 《内网渗透测试:绕过最新防火墙策略》
  • C#高级编程:设计模式原则
  • 数据分析预备篇---Pandas的Series
  • langChain存储文档片段,并进行相似性检索
  • 【神经网络与深度学习】通俗易懂的介绍非凸优化问题、梯度消失、梯度爆炸、模型的收敛、模型的发散
  • GITLAB跑gradle项目 不借助maven-publish直接上传到nexus私人仓库
  • C++STL——map和set的使用
  • 使用DevEco Studio性能分析工具高效解决鸿蒙原生应用内存问题
  • 免费专业级 PDF 处理!SolidPDF OCR 识别 + 精准转换批量处理
  • 【源码+文档+调试讲解】驾校报名小程序2
  • 嵌入式开发学习日志(数据结构--顺序结构单链表)Day19
  • 在scala中sparkSQL连接masql并添加新数据
  • 分割一切(SAM) 论文阅读:Segment Anything
  • c++ std库中的文件操作学习笔记
  • QEMU模拟32位ARM实现自定义系统调用
  • CodeBuddy 中国版 Cursor 实战:Redis+MySQL双引擎驱动〈王者荣耀〉战区排行榜
  • RAG之大规模解析 PDF 文档全流程实战
  • 网络协议分析 实验四 ICMPv4与ICMPv6
  • web-ui开源程序是建立在浏览器使用的基础上,旨在使 AI 代理可以访问网站
  • 人民日报评外卖平台被约谈:摒弃恶性竞争,实现行业健康发展
  • 国家林草局原党组成员、副局长李春良接受审查调查
  • 学者的“好运气”:读本尼迪克特·安德森《椰壳碗外的人生》
  • 澎湃思想周报|欧洲胜利日之思;教育监控与学生隐私权争议
  • 梅花奖在上海|“我的乱弹我的团”,民营院团首次入围终评
  • 王毅同印度国家安全顾问多瓦尔通电话