剑指offer编程题解法汇总44-翻转单词序列
2023-09-11 14:18:52 时间
原题链接:翻转单词序列_牛客题霸_牛客网
描述
牛客最近来了一个新员工Fish,每天早晨总是会拿着一本英文杂志,写些句子在本子上。同事Cat对Fish写的内容颇感兴趣,有一天他向Fish借来翻看,但却读不懂它的意思。例如,“nowcoder. a am I”。后来才意识到,这家伙原来把句子单词的顺序翻转了,正确的句子应该是“I am a nowcoder.”。Cat对一一的翻转这些单词顺序可不在行,你能帮助他么?
示例1
输入:
"nowcoder. a am I"
返回值:
"I am a nowcoder."
题目解析:
先记录一个end的位置,从后向前查找,如果遇到空格,则截取当前位置到end之间的字符串进行拼接。
还有一种场景是如果i==0了,则代表完成了,也要进行一次截取。
代码:
public static void main(String[] args) {
Solution solution = new Solution();
String s = solution.ReverseSentence("nowcoder. a am I");
System.out.println(s);
}
public String ReverseSentence(String str) {
StringBuilder builder = new StringBuilder();
int end = str.length();
for (int i = str.length() - 1; i >= 0; i--) {
if (str.charAt(i) == 32) {
builder.append(str, i + 1, end);
builder.append(' ');
end = i;
continue;
}
if (i == 0) {
builder.append(str, 0, end);
}
}
return builder.toString();
}
相关文章
- Newtonsoft.Json序列化和反序列之javascriptConvert.SerializeObject,DeserializeObject,JsonWriter,JsonReader
- Java实现 LeetCode 491递增子序列
- java实现第五届蓝桥杯扑克序列
- Java实现 蓝桥杯VIP 算法提高 最长公共子序列
- (动态规划)最长回文子序列、回文子序列个数
- 【二叉树】LeetCode 105. 从前序与中序遍历序列构造二叉树【中等】
- 用R分析时间序列(time series)数据
- 表格存储最佳实践:一种用于存储时间序列数据的表结构设计
- 编程笔试(解析及代码实现):序列重排之给一个长度为n的序列A,求找出某种排列方式使得相邻两个数的差值之和最大并求出该最大值
- 编程笔试(解析及代码实现):求和为N的正整数序列之实现一个函数,输入为一个正整数N (比如100),输出为所有和等于N的[连续]正整数序列
- Algorithm:C++/python语言实现之求旋转数组最小值、求零子数组、求最长公共子序列和最长公共子串、求LCS与字符串编辑距离
- erlang 小程序:整数序列,搜索和为正的最长子序列
- 【数字信号处理】基本序列 ( 基本序列列举 | 单位脉冲序列 | 单位脉冲函数 | 离散单位脉冲函数 | 单位脉冲函数 与 离散单位脉冲函数的区别 )
- 【Leetcode刷题Python】300. 最长递增子序列
- m序列发生器——Verilog设计
- 【LeetCode】300.最长上升子序列
- Python少儿编程入门篇(6)序列基础、成员和身份运算