栈的应用(删除字符串中的所有相邻重复项)

例如:s="abbaca",返回"ca"。

分析:因为要重复进行删除操作,知道无法进行删除,通过普通遍历去判断当前元素与前一个元素是否相同比较麻烦。所以选择用栈来进行一次遍历。

遍历该字符串,判断当前字母是否与栈顶元素相同,如果相同,就删除栈顶,并接着去遍历下一个元素,这样就相当于删除了这两个挨着的元素。如果不相同,就将这个字母加入到栈中。

最终,栈中剩余的元素就是无法进行删除的字母。

通过损害栈来遍历栈中的字母。遍历一个,就弹出一个,直到栈为空,得到一个字符串。

因为栈是先进后出,所以最后需要对得到的字符串进行翻转。

代码如下:

 改进版:定义一个res,直接对s进行操作,如果当前遍历的字母与res的最后一个字母相同,就说明res的最后一个字母的后面有一样的字母,此时就删除res的最后一个字母;

如果当前遍历的字母与res的最后一个字母不相同,就说明此时res的最后一个字母后方没有与其一样的字母对应,可以直接加入到res中。

改进:不用定义stack,也不用单独去遍历stack。

代码如下:

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值