题解 | #句子逆序#

句子逆序

http://www.nowcoder.com/practice/48b3cb4e3c694d9da5526e6255bb73c3

题意整理。

  • 输入一行英文句子,单词间以空格隔开。
  • 以单词为单位逆序处理,并输出。

方法一(反转)

1.解题思路

  • 首先将输入的句子变为字符数组。
  • 将字符数组整体反转,然后再反转每一个单词,即可得到预期的结果。最后将字符数组转化为字符串并输出。

图解展示: alt

2.代码实现

import java.util.Scanner;

public class Main{
    
    public static void main(String[] args){
        Scanner sc=new Scanner(System.in);
        String s=sc.nextLine();
        //转化为字符数组
        char[] arr=s.toCharArray();
        //整体反转
        reverse(arr,0,arr.length-1);
        int index=0;
        for(int i=0;i<arr.length;i++){
            if(arr[i]==' '){
                //局部反转
                reverse(arr,index,i-1);
                index=i+1;
            }
        }
        //局部反转最后一个单词
        reverse(arr,index,arr.length-1);
        //转为为字符串,并输出
        System.out.println(String.valueOf(arr));
    }
    
    //字符数组反转
    private static void reverse(char[] arr,int i,int j){
        while(i<j){
            //交换对应位置的值
            char temp=arr[i];
            arr[i]=arr[j];
            arr[j]=temp;
            //移动指针
            i++;
            j--;
        }
    }
}

3.复杂度分析

  • 时间复杂度:输入的句子长度不超过1000,局部反转和整体反转的时间复杂度均为常数级别,所以时间复杂度为O(1)O(1)
  • 空间复杂度:需要额外常数级别的空间,所以空间复杂度为O(1)O(1)

方法二(字符串分割)

1.解题思路

  • 新建res,用于记录结果。
  • 然后将输入的句子以空格为单位,分割为字符串数组。
  • 对得到的字符串数组进行逆序遍历,将对应的单词添加到res。
  • 遍历完成后,将res转为字符串,并输出。

2.代码实现

import java.util.Scanner;

public class Main{
    public static void main(String[] args){
        Scanner sc=new Scanner(System.in);
        String s=sc.nextLine();
        //新建res,用于记录结果
        StringBuilder res=new StringBuilder();
        //以空格为单位,分割为字符串数组
        String[] arr=s.split(" ");
        //逆序遍历
        for(int i=arr.length-1;i>=0;i--){
            //添加对应的单词
            if(i!=0){
                res.append(arr[i]+" ");
            }
            else{
                res.append(arr[i]);
            }
        }
        System.out.println(res.toString());
    }
}

3.复杂度分析

  • 时间复杂度:字符串长度不超过1000,分割及逆序遍历的时间复杂度均为常数级别,所以时间复杂度为O(1)O(1)
  • 空间复杂度:需要额外常数级别的空间,所以空间复杂度为O(1)O(1)
xqxls的题解 文章被收录于专栏

牛客题解

全部评论

相关推荐

和蔼:在竞争中脱颖而出,厉害! 但是有一个小问题:谁问你了?😡我的意思是,谁在意?我告诉你,根本没人问你,在我们之中0人问了你,我把所有问你的人都请来 party 了,到场人数是0个人,誰问你了?WHO ASKED?谁问汝矣?誰があなたに聞きましたか?누가 물어봤어?我爬上了珠穆朗玛峰也没找到谁问你了,我刚刚潜入了世界上最大的射电望远镜也没开到那个问你的人的盒,在找到谁问你之前我连癌症的解药都发明了出来,我开了最大距离渲染也没找到谁问你了我活在这个被辐射蹂躏了多年的破碎世界的坟墓里目睹全球核战争把人类文明毁灭也没见到谁问你了
点赞 评论 收藏
分享
11-08 13:58
门头沟学院 Java
程序员小白条:竟然是蓝桥杯人才doge,还要花钱申领的offer,这么好的公司哪里去找
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务