fezaoduke / fe-practice-hard

晚练课
69 stars 6 forks source link

第 61 期(数据结构-栈):栈的应用 #64

Open wingmeng opened 5 years ago

wingmeng commented 5 years ago

上一期介绍了 栈和栈的模拟,这一期来看看栈的应用。

依稀记得 LeetCode 看过一道判断字符串是否为回文的题,除了用反转字符串数组比较的方法外,还可以利用栈的特性来解决。

回文:如果一个字符串从前往后写和从后往前写都是一样的,则称之为回文。例如:"dad", "racecar" 就是回文。

思路: 将字符串每个字符按从左到右的顺序压入栈,当所有字符都入栈后,栈内就保存了一个天然的反转字符串,最后的字符在栈顶,第一个字符在栈底。

接下来依次弹出栈中的每个字符就可以得到一个新字符串,再和原来的字符串进行对比,如果相等,就可以判断是一个回文了。

上码:

代码中用到了上一期中的 Stack

function isPalindrome(str) {
  let stack = new Stack();

  str.split('').map(s => stack.push(s));

  let rStr = '';

  while(stack.size() > 0) {
    rStr += stack.pop();
  }

  return str === rStr;
}