Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Appearance settings

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

Copy link
Copy link
@wingmeng

Description

@wingmeng
Issue body actions

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

依稀记得 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;
}

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions

      Morty Proxy This is a proxified and sanitized view of the page, visit original site.