![7b1b898e10eb08405faebe171a3b1d62.png](https://i-blog.csdnimg.cn/blog_migrate/a624a9a6baea5feaf9e75986da45ad1a.jpeg)
题目描述
给定一个字符串,你需要反转字符串中每个单词的字符顺序,同时仍保留空格和单词的初始顺序。
示例 1:
输入: "Let's take LeetCode contest"
输出: "s'teL ekat edoCteeL tsetnoc"
注意: 在字符串中,每个单词由单个空格分隔,并且字符串中不会有任何额外的空格。
解题思路
双指针替换
- 将字符串格式改为rune (主要考虑中文字符的问题)
- 遍历字符串,遇到空格时停止
- 使用双指针,对本单词进行字符替换指针一:代表单词的第一个下标指针二:代表单词最后一个下标
- 字符替换
- 字符串最后一个字符是否是空格
show me the code (golang)
![47e3273b5e1eeb0ec16468bd1edfc971.png](https://i-blog.csdnimg.cn/blog_migrate/b5760312733752931732b8cb55128bf6.png)
代码
总结
提交执行结果如下,如果将字符串转化为byte则效率会更好。关于中文字符的问题,题目中说明的是单词,但在实际使用中,你并不清楚别人会给你传递什么参数过来。所以中文字符还是需要考虑
rune的结果:
![2b869726c344abb603905ac014b0010f.png](https://i-blog.csdnimg.cn/blog_migrate/cf137a9f096bc2a11b0e0bba5cf73f4c.png)
byte的结果:
![7bdd04fea7426ac00eb720f405e90f38.png](https://i-blog.csdnimg.cn/blog_migrate/d1008f1104866e1e229344144ab5fbb2.png)