3039. 进行操作使字符串为空

简介: 3039. 进行操作使字符串为空

说在前面

🎈不知道大家对于算法的学习是一个怎样的心态呢?为了面试还是因为兴趣?不管是出于什么原因,算法学习需要持续保持。

题目描述

给你一个字符串 s

请你进行以下操作直到 s

  • 每次操作 依次 遍历 'a''z',如果当前字符出现在 s 中,那么删除出现位置 最早 的该字符。

请你返回进行 最后 一次操作 之前 的字符串 s

示例 1:

输入: s = "aabcbbca"
输出: "ba"
解释: 我们进行以下操作:
- 删除 s = "aabcbbca" 中加粗加斜字符,得到字符串 s = "abbca" 。
- 删除 s = "abbca" 中加粗加斜字符,得到字符串 s = "ba" 。
- 删除 s = "ba" 中加粗加斜字符,得到字符串 s = "" 。
进行最后一次操作之前的字符串为 "ba" 。

示例 2:

输入: s = "abcd"
输出: "abcd"
解释: 我们进行以下操作:
- 删除 s = "abcd" 中加粗加斜字符,得到字符串 s = "" 。
进行最后一次操作之前的字符串为 "abcd" 。

提示:

  • 1 <= s.length <= 5 * 10^5
  • s 只包含小写英文字母。

解题思路

首先创建一个空对象 map,用于记录字符串中每个字符出现的次数。同时初始化变量 max 为 0,用于记录最大的字符出现次数。

接下来使用一个循环遍历字符串 s,对每个字符进行处理。在循环中,将当前字符 s[i] 作为键,将其在 map 对象中的值加 1,并更新 max 的值为当前字符出现次数和 max 的较大值。

然后,根据 map 对象中的字符出现次数,倒序遍历字符串 s。如果当前字符的出现次数等于 max,则将该字符从 map 对象中删除,并将该字符加到结果字符串 str 的前面。

最后,返回结果字符串 str。

该算法的时间复杂度为 O(n),其中 n 是字符串 s 的长度。它需要遍历两次字符串,一次用于统计字符出现次数,一次用于构建结果字符串。空间复杂度取决于字符串中不同字符的数量,为 O(k),其中 k 是字符串中不同字符的数量。

AC代码

/**
 * @param {string} s
 * @return {string}
 */
var lastNonEmptyString = function (s) {
  const map = {};
  let max = 0;
  for (let i = 0; i < s.length; i++) {
    map[s[i]] = (map[s[i]] || 0) + 1;
    max = Math.max(max, map[s[i]]);
  }
  let str = "";
  for (let i = s.length - 1; i >= 0; i--) {
    let k = s[i];
    if (map[k] === max) {
      delete map[k];
      str = k + str;
    }
  }
  return str;
};

公众号

关注公众号『前端也能这么有趣』,获取更多有趣内容。

说在后面

🎉 这里是 JYeontu,现在是一名前端工程师,有空会刷刷算法题,平时喜欢打羽毛球 🏸 ,平时也喜欢写些东西,既为自己记录 📋,也希望可以对大家有那么一丢丢的帮助,写的不好望多多谅解 🙇,写错的地方望指出,定会认真改进 😊,偶尔也会在自己的公众号『前端也能这么有趣』发一些比较有趣的文章,有兴趣的也可以关注下。在此谢谢大家的支持,我们下文再见 🙌。

目录
相关文章
|
JSON 小程序 JavaScript
小程序根据返回值是否为空判断标签是否显示
小程序根据返回值是否为空判断标签是否显示
107 0
|
3月前
|
前端开发 JavaScript
判断数组为空的方法有哪些?
本文介绍了多种判断数组是否为空的方法,包括使用 `length` 属性、隐式类型转换、`toString()`、`join()`、`every()`、`reduce()`、`filter()`、`some()` 方法以及循环。每种方法都有其适用场景,其中使用 `length` 属性和隐式类型转换最为常见和简单。文章首发于微信公众号“前端徐徐”。
381 2
判断数组为空的方法有哪些?
|
8月前
判断字符类型
该内容描述了一个字符判断和转换的逻辑:输入字符,根据条件进行操作。如果字符是大写字母,转为小写;如果是小写字母,转为大写;若是数字,输出其ASCII值;否则输出&quot;错误&quot;。判断条件包括:大写字母ASCII值在&#39;A&#39;和&#39;Z&#39;之间,小写字母在&#39;a&#39;和&#39;z&#39;之间,数字在&#39;0&#39;和&#39;9&#39;之间。转换利用ASCII值差32的特性,通过if-else if语句实现。内容中还包括两幅示例图片,显示了程序执行的结果。
56 1
|
8月前
|
算法 前端开发 索引
判断对象是否为空
判断对象是否为空
76 0
字符串的相关操作
字符串的相关操作
|
前端开发
你真的会判断对象是否为空吗?
一个小小的判空,却很可能让你吃了大亏,如果一个判空没有做好,那么里面的逻辑就完全裸露了,相信你一定吃过 `NullPointerException` 的苦头!
128 0
StringUtils判断字符串是否为空
StringUtils判断字符串是否为空
142 0
StringUtils判断字符串是否为空
判断一个字符串是否全部相同
判断一个字符串是否全部相同
97 0
判断一个字符串是否全部相同
判断一个字符串是否全部不相同
判断一个字符串是否全部不相同
85 0
判断一个字符串是否全部不相同
|
存储 安全 C语言
C/C++: 字符串的一些操作
字符串是一种非常重要的数据类型,但是C语言不存在显式的字符串类型,C语言中的字符串都以字符串常量的形式出现或存储在字符数组中。同时,C 语言提供了一系列库函数来对操作字符串,这些库函数都包含在头文件 string.h 中。
219 0