[Leetcode Solution] Reverse Words in a String

The problem description is simple enough.

For example, "the sky is blue" => "blue is sky the".

However, this problem is not easy as it seems. We have to deal with the leading and trailing spaces, also the duplicate spaces between to "words" - any visible characters except space could constitute words, such as "^_^" , "<><", "What?!" etc.


One of the tricky way to tackle the problem is use "split" and "join" with Python.

' '.join(raw_input().split(" ")[::-1])


Python is fantastic, but it can hardly satisfy the interviewer. 


Usually, we are asked to use a "real programming language" like C++ or Java in the interview. Is there a simple way like the python code above?

The answer is yes.

As we know, Implementing your own trim/strip/join is so annoying, and can bring many potential bugs in your code. But, getline helps you tokenize a string easily with a single delimiter.

class Solution {
public:
    void reverseWords(string &s)
    {
        string token;
        istringstream iss(s);
        s = "";
        while (getline(iss, token, ' ')) {
            if (token.empty()) {
                continue;
            }
            s = token + (s.empty()? "":" ") + s;
        }
    }
};

Oh, well. It is tricky, too. Because it rely too much on build-in functions of C++. But it is much better. :)

If we are forced to write a full version in-place "reverseWords" algorithm all ourselves, what should we do?


class Solution {
public:
    void reverseWords(string &s);
private:
    void trim(string &s);
};

void Solution::reverseWords(string &s) {
    trim(s);
    reverse(s. begin(), s.end());
    size_t len = s.length();
    for (size_t i = 0, pre = 0; i <= len; i++) {
        if (isspace(s[i]) || i == len) {
            reverse(s.begin() + pre, s.begin() + i);
            pre = i + 1;
        }
    }
}

void Solution::trim(string &s) {
    size_t len = s.length();
    int p = 0, token = 0;
    for (size_t i = 0; i < len; i++) {
        if (isspace(s[i])) {
            token = 0;
            continue;
        }
        if (!token && p) {
            s[p++] = ' ';
        }
        s[p++] = s[i];
        token++;
    }
    s.erase(p, len);
}

The code is neat because it obeys the "Linus' indentation rule" and simple enough for interviewer to understand quickly.

Linus' Indentation Rule

The answer to that is that if you need more than 3 levels of indentation, you're screwed  anyway, and should fix your program.


EXTENSION:

What should we do if there are multiple delimiters? For example, "The#world*is&gray?"

> boost::split(vector, string, boost::is_any_of("#*&"));

> strpbrk: http://www.cplusplus.com/reference/cstring/strpbrk/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
LeetCode是一个面向编程准备面试的在线平台,它提供了各种编程题目来帮助开发人员提高算法和数据结构的能力。下面是一个使用Java进行LeetCode刷题的指南: 1. 熟悉题库:首先,你需要熟悉LeetCode的题库。了解各种类型的题目,比如数组、字符串、链表、树等等,并了解它们对应的解决方法。 2. 制定计划:根据自己的时间和能力安排一个刷题计划,每天或每周刷一定数量的题目。有计划地刷题可以保证你的学习进度。 3. 注重基础:LeetCode要求高效的算法和数据结构知识,所以确保你掌握了一些基本的数据结构和算法,比如数组、链表、栈、队列、二叉树、图等等。 4. 解题过程:当你开始解题时,首先仔细阅读题目描述,并理解问题的要求。然后分析问题,尽量找到一种简单而高效的解决方案。 5. 编码实现:在理解和分析问题之后,使用Java编写代码来解决问题。编写简洁、高效的代码可以提高你的编码能力。 6. 测试和优化:编写测试用例来验证你的代码是否正确,并分析你的代码的时间复杂度和空间复杂度。根据测试结果,进行代码优化以提高性能。 7. 学习他人的解决方案:LeetCode上有很多高手,他们在解决问题时可能采用了一些巧妙的解决方案。阅读和学习他们的代码可以帮助你提高自己的解题能力。 8. 多实践,多思考:不仅仅完成题目,还需要总结经验和教训。多思考为什么这个解决方案是高效的,以及如何在其他类似问题上应用相同的思路。 通过遵循这个LeetCode刷题指南,你可以提高自己的算法和数据结构的能力,为面试做好准备。刷题不仅仅是为了通过面试,更是提升自己的编程技能和思维能力的一种训练。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值