查看: 272|回复: 0
收起左侧

[高频题] 这道变种题怎么实现1209变种

|只看干货
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   85% (543)
 
 
14% (91)    👎

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看附件。没有帐号?注册账号

x
1209. Remove All Adjacent Duplicates in String II
原题是 k个字符消掉
变种是任意连续的直接删掉

我code 如下 ,网上抄的, 测试发现有bug
  1. public static String removeAdjDup(String str) {
  2.         // base case
  3.         if (str == null || str.length() == 0) {
  4.             return str;
  5.         }

  6.         char[] chars = str.toCharArray();

  7.         // `k` maintains the index of the next free location in the result,
  8.         // and `i` maintains the current index of the string
  9.         int i, k = 0;

  10.         // start from the second character
  11.         for (i = 1; i < chars.length; i++) {
  12.             // if the current character is not the same as the
  13.             // previous character, add it to the result
  14.             if (chars[i - 1] != chars[i]) {
  15.                 chars[k++] = chars[i - 1];
  16.             } else {
  17.                 // remove adjacent duplicates
  18.                 while (i < chars.length && chars[i - 1] == chars[i]) {
  19.                     i++;
  20.                 }
  21.             }
  22.         }

  23.         // add the last character to the result
  24.         chars[k++] = chars[i - 1];

  25.         // construct a string with the first `k` chars
  26.         String s = new String(chars).substring(0, k);

  27.         // start again if any duplicate is removed
  28.         if (k != chars.length) {
  29.             return removeAdjDup(s);            // Schlemiel painter’s algorithm
  30.         }

  31.         // if the algorithm didn't change the input string, that means
  32.         // all the adjacent duplicates are removed
  33.         return s;
  34.     }

  35.         public static void main(String [] args){
  36.         System.out.print(removeAdjDup( "acbbcaac"));
  37.     }
复制代码
有没有高人帮忙实现下 ,感激不尽

上一篇:加米 lc543. Diameter of Binary Tree 的recursion
下一篇:啥时候算是ready
您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

>
快速回复 返回顶部 返回列表