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

3174、清除数字

3174、[简单] 清除数字

1、题目描述

给你一个字符串 s 。你的任务是重复以下操作删除 所有 数字字符:

  • 删除 第一个数字字符 以及它左边 最近非数字 字符。

请你返回删除所有数字字符以后剩下的字符串。

2、解题思路

  1. 遍历字符串

    • 我们需要逐个遍历字符串中的每个字符,找到数字字符,并删除其左侧最近的非数字字符。
  2. 双指针法

    • 我们可以使用两个指针 left 和 right 来实现遍历和删除的过程:
      • right 用于遍历字符串 s
      • left 用于构造删除后的新字符串,逐步替换字符。
  3. 处理逻辑

    • 当我们遇到一个数字字符时,删除左侧最近的非数字字符,这可以通过将 left 指针左移一位实现。

    • 当遇到非数字字符时,将其放到新的位置上,并移动 left 指针。

  4. 最后清理字符串

    • 遍历结束后,使用 erase 函数删除字符串中多余的字符,最终得到所需结果。

3、代码实现

class Solution {
public:string clearDigits(string s) {int n = s.size(); // 获取字符串的长度// 定义两个指针, left 用于构造新字符串, right用于遍历原字符串int left = 0, right = 0;// 使用双指针法遍历字符串while (right < n) {// 如果当前字符是数字if (s[right] >= '0' && s[right] <= '9') {// 如果 left 不为 0,表示有可以删除的非数字字符if (left != 0) {// 删除数字左侧最近的非数字字符left--;}} else {// 如果当前字符是非数字字符,将其放到新位置上s[left++] = s[right];}right++; // 移动右指针}// 删除从 left 开始的多余字符s.erase(left);// 返回处理后的字符串return s;}
};

4、复杂度分析

  • 时间复杂度:O(n),其中 n 是字符串的长度。我们只遍历字符串一次。

  • 空间复杂度:O(1),只使用了常数级别的额外空间来存储指针。

5、总结

这个问题通过双指针法实现对字符串的遍历和处理,核心在于如何高效地删除数字字符及其左侧相邻的非数字字符。通过对指针的巧妙控制,我们能够在一次遍历中完成所有操作,并且不需要额外的空间复杂度。


http://www.mrgr.cn/news/42504.html

相关文章:

  • vue3实现excel文件预览和打印功能
  • Leetcode 1498. 满足条件的子序列数目
  • 【路径规划】基于人工势场(APF)算法、Vortex APF算法、Safe APF算法和动态 Windows 方法的比较
  • linux基础指令的认识
  • 如何使用ssm实现中学生课后服务的信息管理与推荐+vue
  • 【洛谷】P1352 没有上司的舞会 的题解
  • SpringBoot开发:古典舞在线交流平台的架构与实现
  • dns服务器部署
  • CSS计数器
  • ssh连接阿里云长连接
  • HISAT 软件比对算法及性能简介
  • Python的file.read方法
  • 工业物联网在能源管理中的应用
  • vscode报错No module named ‘Crypto‘
  • python爬虫 - 初识爬虫
  • SF-HCI-SAP问题收集20:Metadata导入的时间格式错误问题
  • 程序猿成长之路之设计模式篇——设计模式简介
  • python如何比较字符串
  • 【Git】vscode链接github拉去镜像
  • 梗百科——信号和槽机制