这是小川的第389次更新,第419篇原创

01 看题和准备

今天介绍的是LeetCode算法题中Easy级别的第251题(顺位题号是1047)。给定一个小写字母的字符串S,重复删除两个相邻且相等的字母。

我们在S上反复删除,直到我们再也无法删除。

在完成所有此类重复删除后返回最后一个字符串。保证答案是独一无二的。

例如:

输入:"abbaca"

输出:"ca"

说明:在"abbaca"中我们可以删除"bb",因为字母相邻且相等,这是唯一可能的移动。这一举动的结果是字符串是"aaca",其中只有"aa"是可能的,所以最后的字符串是"ca"。

注意

  • 1 <= S.length <= 20000

  • S仅由英文小写字母组成。

02 第一种解法

题目的意思是依次比较S中相邻的两个字母,如果相同,就删除掉,组成一个新的字符串,继续刚才的操作,直到最后S中没有相邻的重复的字母。

思路:定义一个布尔类型变量flag,控制上一次遍历S中的字母时,是否存在相邻的重复字母。使用两层循环,外层控制是否可以继续删除,内层遍历S中相邻的字母,如果相同就删掉,这里采取截取字符串的方式来生成新的字符串,同时将flag改为true,以便继续外层循环。

public String removeDuplicates(String S) {
boolean flag = true;
while (flag) {
flag = false;
int n = S.length()-1;
for (int i=0; i<n; i++) {
if (S.charAt(i) == S.charAt(i+1)) {
S = S.substring(0, i)+
S.substring(i+2, S.length());
flag = true;
break;
}
}
}
return S;
}

03 第二种解法

我们还可以借助来实现,借助其后进先出的特性。

思路:遍历S中的字母,如果当前字母和栈顶的字母相等,就将栈顶的字母移除,如果不相等,就压入栈顶,直到遍历完所有字母。最后将栈中的字母拼接到StringBuilder中去,转为字符串时,要反转,因为最先出栈的字母是S中较后面的。

public String removeDuplicates2(String S) {
Stack<Character> stack = new Stack<Character>();
int n = S.length();
for (int i=0; i<n; i++) {
if (!stack.isEmpty() && S.charAt(i) == stack.peek()) {
stack.pop();
} else {
stack.push(S.charAt(i));
}
}
StringBuilder sb = new StringBuilder();
while (!stack.isEmpty()) {
sb.append(stack.pop());
}
return sb.reverse().toString();
}

04 第三种解法

同样借助栈的思路,但是我们可以不使用栈,通过StringBuilder来完成类似栈的操作。

思路:创建一个StringBuilder对象,遍历S中的字母,如果当前字母和StringBuilder中的最后一个字母相等,就将StringBuilder中的最后一个字母删除,否则就继续往后拼接。

public String removeDuplicates3(String S) {
StringBuilder sb = new StringBuilder();
int n = S.length();
for (int i=0; i<n; i++) {
int size = sb.length();
if (size > 0 && sb.charAt(size-1) == S.charAt(i)) {
sb.deleteCharAt(size-1);
} else {
sb.append(S.charAt(i));
}
}
return sb.toString();
}

05 第四种解法

同样借助栈的思路,我们还可以利用char数组来实现。

思路:创建一个长度和S相等的char数组,遍历S中的字母,如果当前字母和char数组中的最后一个字母相等,就将索引前移,下次再往char数组中添加元素时,就会根据新的索引重新赋值,起到移除重复字母的效果。

public String removeDuplicates4(String S) {
int n = S.length(), index = 0;
char[] arr = new char[n];
for (int i=0; i<n; i++) {
if (index > 0 && arr[index-1] == S.charAt(i)) {
index--;
} else {
arr[index++] = S.charAt(i);
}
}
return new String(arr, 0, index);
}

06 小结

算法专题目前已连续日更超过七个月,算法题文章257+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。

以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!

LeetCode.1047-重复删除字符串中的所有相邻重复项的更多相关文章

  1. LeetCode 1047. 删除字符串中的所有相邻重复项(Remove All Adjacent Duplicates In String)

    1047. 删除字符串中的所有相邻重复项 1047. Remove All Adjacent Duplicates In String 题目描述 LeetCode1047. Remove All Ad ...

  2. LeetCode#1047-Remove All Adjacent Duplicates In String-删除字符串中的所有相邻重复项

    一.题目 给出由小写字母组成的字符串 S,重复项删除操作会选择两个相邻且相同的字母,并删除它们. 在 S 上反复执行重复项删除操作,直到无法继续删除. 在完成所有重复项删除操作后返回最终的字符串.答案 ...

  3. jst通用删除数组中重复的值和删除字符串中重复的字符

    以下内容属于个人原创,转载请注明出处,非常感谢! 删除数组中重复的值或者删除字符串重复的字符,是我们前端开发人员碰到很多这样的场景.还有求职者在被面试时也会碰到这样的问题!比如:问删除字符串重复的字符 ...

  4. C# 删除字符串中的中文

    /// <summary> /// 删除字符串中的中文 /// </summary> public static string Delete中文(string str) { s ...

  5. 找出字符串中第一个不重复的字符(JavaScript实现)

    如题~ 此算法仅供参考,小菜基本不懂高深的算法,只能用最朴实的思想去表达. //找出字符串中第一个不重复的字符 // firstUniqueChar("vdctdvc"); --& ...

  6. PAT 字符串-02 删除字符串中的子串

    /* 2 *PAT 字符串-02 删除字符串中的子串 3 *2015-08-09 4 作者:flx413 5 */ #include<stdio.h> #include<string ...

  7. JS中删除字符串中的空格

    问题描述:         在进行字符串操作时,由于字符串中存在较多的空格,因此需要考虑取消字符串中的空格 问题解决:       (1)删除字符串中的前导空格(字符串的前面的空格): 注意:这里使用 ...

  8. 删除字符串中多余的空白字符和空行(C语言实现)

    要求:处理一个字符串,删除字符串中多余的空格.水平制表符和空行,并满足下列要求: (1)对原字符串只能进行一次扫描.(2)不允许申请新的空间.(3)处理后的字符串的首尾不能有空格.制表符和空行.(4) ...

  9. 算法基础:删除字符串中出现次数最少的字符(Golang实现)

    描写叙述: 实现删除字符串中出现次数最少的字符.若多个字符出现次数一样,则都删除.输出删除这些单词后的字符串. 字符串中其他字符保持原来的顺序. 输入: 字符串仅仅包括小写英文字母, 不考虑非法输入, ...

随机推荐

  1. C#的Winform多语言实现(resx文件)

    1. 简体中文 2. 繁体中文 3. 英文 下面子丰介绍一下实现的过程: 1. 为每个窗口创建相应语言的resx文件.子丰以英文为例,右键->添加->新建项->资源文件,文件名为窗口 ...

  2. 注意vue-router嵌套路由的问题:子路由组件中的class名和本组件页面的class名相同时,子路由组件的样式被覆盖。

    注意vue-router嵌套路由的问题:子路由组件中的class样式被覆盖,当需要用到路由嵌套时,clas命名时注意不要相同. 点击查看上一篇vue-router嵌套路由具体 例子: 子路由a组件中: ...

  3. 【leetcode】740. Delete and Earn

    题目如下: Given an array nums of integers, you can perform operations on the array. In each operation, y ...

  4. [转载]blktrace分析IO

    前言 上篇博客介绍了iostat的一些输出,这篇介绍blktrace这个神器.上一节介绍iostat的时候,我们心心念念希望得到块设备处理io的service time,而不是service time ...

  5. ASP.NET通过反射生成sql语句

    最近对接一个接口,需要通过xml序列化成实体后添加额外信息后批量插入数据库,需要手动拼sql.因为涉及多张表,拼凑很麻烦而且容易出错,所以写了两个工具方法来生成sql,先写到博客里面,以便以后不时之需 ...

  6. 01Two Sum题解

    Tow Sum 原题概述: Given an array of integers, return indices of the two numbers such that they add up to ...

  7. Unity3D_(游戏)控制物体的上、下、左、右移动

    通过键盘上↑.↓.←.→实现对物体的控制 using System.Collections; using System.Collections.Generic; using UnityEngine; ...

  8. 微信小程序_(视图)简单的swiper容器

    swiper容器效果 官方文档:传送门 swiper容器可实现简单的轮播图效果 结构程序 Page({ /** * 页面的初始数据 */ data: { }, /** * 生命周期函数--监听页面加载 ...

  9. MySql中根据一列状态值查询状态的个数

    最近搞报表的项目,要写数据库sql语句,根据状态值查询状态的个数,这个开始难为到我了,不过已经有解决办法了. 在数据库表中有一个字段是状态(zt),这里面有1-7这7个状态,现在查询每个状态的数量,并 ...

  10. opencv_将图像上的4个点按逆时针排序

    1:代码如下: #include "stdafx.h" #include "cxcore.h" #include "cvcam.h" #in ...