[LeetCode]557. Reverse Words in a String III(反转字符串 III)

本文介绍了一种简单的方法来反转字符串中每个单词内的字符顺序,同时保持原有的空格和单词顺序不变。通过C++实现,文章详细解释了如何将句子分割成单词并逐一反转。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

557. Reverse Words in a String III

Given a string, you need to reverse the order of characters in each word within a sentence while still preserving whitespace and initial word order.

Example 1:

Input: "Let's take LeetCode contest"
Output: "s'teL ekat edoCteeL tsetnoc"

Note:

  • In the string, each word is separated by single space and there will not be any extra space in the string.
  • 在字符串中,每个单词都以单个空格分隔,字符串中不会有任何额外的空格。

题目大意:

给定一个字符串,需要颠倒一个句子中每个单词中的字符顺序,同时仍保留空格和初始单词顺序。

挺简单的题,只需要将句子中每个单词中的字母颠倒顺序,其他东西保持不变就行。

思路:

  1. 英文句子分割成一个个单词
  2. 将每个单词反转 (以单词中间字母为中心,前后对称位置的字母交换位置)

代码如下:

#include <iostream>
#include <string>
using namespace std;
class Solution {
public:
    //思路:
    //1.英文句子分割成一个个单词
    //2.将每个单词反转 (以单词中间字母为中心,前后对称位置的字母交换位置)
    string reverseWords(string s) {
        string res = s;//复制英文句子
        int left = 0;//记录单词位置的左下标
        int right = 0;//记录单词位置的右下标
        for(int i=0; i<res.length()+1; i++){//s.length()+1 是为了遍历字符串最后的结束符'\0'
            if(res[i]==' ' || res[i]=='\0'){//若s="asd dfg" 则s[3]=' ',s[7]='\0'
                left = right;
                right = i-1;//空格或结束符的左邻字符下标 即为 目前单词位置的右下标
                int L = left;
                int R = right;
                for(; L<R; ++L,--R){//反转单词
                    char temp = res[L];
                    res[L] = s[R];
                    res[R] = temp;
                }
                right = i+1;//空格或结束符的右邻字符下标 即为 下个单词位置的左下标
            }
        }
        return res;
    }
};
int main()
{
    Solution A;
    string a;
    getline(cin,a);
    //cin >> a;//只能输入没有空格的字符串,当输入中含有空格,则只能输出空格之前的字符
    cout << A.reverseWords(a) << endl;
    return 0;
}

注意:

  1. 输入不能用cin,cin输入不能包含空格,空格和回车键默认为输入结束,用getline
  2. 结束符一定要遍历,不然最后一个单词不会颠倒
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值