[LeetCode]Reverse Words in a String

本文介绍如何通过编程实现字符串中单词的逆序输出,包括解析字符串、处理特殊字符和输出结果等步骤。

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

题目描述

Given an input string, reverse the string word by word.

For example,
Given s = "the sky is blue",
return "blue is sky the".

将一个字符串中的单词逆序输出

解题思路

最直接的想法就是使用split函数将字符串以“”分割。但再实际过程中出现了麻烦。
测试输入会给一些比较bug的用例,比如“     ”,“  a”,"    a    ".....
而"   a   ".split(" ")的得到数组array.length = 4。这说明数组中有一些元素的值为“”。我们必须将这些考虑进去。

代码

public String reverseWords(String s) {
		String result = "";
		if (s == null || s.equals(""))
			return s;

		String[] array = s.split(" ");
		if (array == null || array.length == 0) {
			return "";
		}

		for (int i = array.length - 1; i >= 0; i--) {
			if(!array[i].equals("")){
				if(result.equals("")){
					result = result + array[i];
				} else{
					result = result + " " + array[i];
				}
				 
			}
		}
		return result;
	}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值