首页 技术 正文
技术 2022年11月20日
0 收藏 462 点赞 3,380 浏览 1047 个字

本题 题目链接

题目描述


我的题解

方法一:库函数split()

  • 要注意str.split()函数:

    • 字符串str前有 n 个空格时,分割出来的字符串列表中会多出 n 个空字符串;
    • 字符串str某两个字符串中有 n 个空格,分割出的字符串列表会多 n-1 个空字符串。
    • 字符串str最后有空格,分割出的字符串列表里不会多出空字符串
  • split()的例子如下:

本题代码如下

    public String reverseWords(String s) {
if (s == null) return s; String[] strList = s.split(" ");
StringBuilder res = new StringBuilder(); for (int i = strList.length - 1; i >= 0; i--) {
if (!"".equals(strList[i])) {
res.append(strList[i]+" ");
}
}
return res.toString().trim();
}

复杂度分析:

时间复杂度 O(N) :各函数时间复杂度如下

  • split() 方法: 为 O(N) ;
  • trim() 方法: 最差情况下(当字符串全为空格时),为 O(N)O(N) ;

空间复杂度 O(N) : 单词列表strList占用线性大小的额外空间。

方法二:双指针

思路分析

  • 声明两个指针 i,j 分别用来确定单词头和单词尾,初始位置均指向字符串尾。倒序遍历字符串:

    • 找到单词尾:指针 i一直向左移动,直到 i<0 或 指向的字符不再是空格时,停止移动,此时把 i 的值赋给j。此步骤确定了单词尾指针。
    • 找到单词头:指针 i 一直向左移动,直到 i<0 或 指向的字符串不再是字母时,停止移动,此时,找到了单词头(单词从下标 i+1 开始到 j 结束)。

代码如下

    public String reverseWords(String s) {
if (s == null) return s;
StringBuilder res = new StringBuilder(); int j = s.length()-1;
int i = j;
while (i >= 0) {
// 找单词尾
while (i >= 0 && s.charAt(i) == ' ') i--;
j = i;
// 找单词头
while (i >= 0 && s.charAt(i)!=' ') i--;
res.append(s.substring(i + 1, j+1)+' '); // 左闭右开
}
return res.toString().trim(); }

复杂度分析

  • 时间复杂度:O(N),N为字符串长度,线性遍历字符串
  • 空间复杂度:O(N),新建的res字符串总长度≤ N,占用O(N)大小的空间
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,076
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,552
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,400
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,176
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,812
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,894