zoukankan      html  css  js  c++  java
  • 剑指:翻转单词顺序

    题目描述

    输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。

    为简单起见,标点符号和普通字母一样处理。

    例如输入字符串 "I am a student.",则输出 "student. a am I"

    样例

    输入:"I am a student."
    
    输出:"student. a am I"
    

    解法

    先对字符串按空格切割成数组,再逆序数组后,最后将元素拼接并返回。

    class Solution {
        /**
         * 翻转单词
         * 
         * @param s 字符串
         * @return 翻转后的字符串
         */
        public String reverseWords(String s) {
            if (s == null || s.length() < 2) {
                return s;
            }
    
            String[] arr = s.split(" ");
            int p = 0, q = arr.length - 1;
            while (p < q) {
                swap(arr, p++, q--);
            }
            return String.join(" ", arr);
        }
        private void swap(String[] arr, int p, int q) {
            String t = arr[p];
            arr[p] = arr[q];
            arr[q] = t;
        }
    }
  • 相关阅读:
    git相关整理
    cookie、sessionStorage和localStorage
    AJAX学习笔记
    json web token
    加密算法
    单点登陆
    给手机网络添加手动代理
    oracle数据库索引
    类加载器
    类加载过程
  • 原文地址:https://www.cnblogs.com/lisen10/p/11649050.html
Copyright © 2011-2022 走看看