牛客-倒置字符串

1.题目描述

2.题目链接

倒置字符串_牛客题霸_牛客网

3.代码解答

java 复制代码
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        String s = scanner.nextLine();
        
        // 按空格分割单词(处理多个连续空格的情况,split(" +") 匹配一个或多个空格)
        String[] words = s.split(" +");
        
        // 反转单词数组
        int left = 0;
        int right = words.length - 1;
        while (left < right) {
            // 交换左右指针的单词
            String temp = words[left];
            words[left] = words[right];
            words[right] = temp;
            left++;
            right--;
        }
        
        // 拼接反转后的单词数组
        StringBuilder result = new StringBuilder();
        for (int i = 0; i < words.length; i++) {
            result.append(words[i]);
            // 最后一个单词后不添加空格
            if (i != words.length - 1) {
                result.append(" ");
            }
        }
        
        System.out.println(result.toString());
    }
}

4.解题思路

1)字符串数组逆序

先把输入的原字符串读入String类型的字符串中,再以正则表达式匹配到的一个或者多个的空格为分界符读入字符串数组中,最后以字符串数组中的字符串元素为单位,逆序排列。

2)双重逆序

先把整个字符串逆序,再对每一个单词进行逆序。但是算法题目中的StringBuilder的reverse方法并不支持部分逆序,只支持全部逆序。在二次逆序的时候,算法题目中的Stringbuilder的subString方法也支持只有start这一种。很不方便而且时间复杂度极高。

5.代码细节

1)正则表达式处理多个空格的情况,同时split方法分割字符串为字符串数组

java 复制代码
// 按空格分割单词(处理多个连续空格的情况,split(" +") 匹配一个或多个空格)
        String[] words = s.split(" +");

2)最后一个字符串数组元素后面不需要拼接空格

java 复制代码
// 最后一个单词后不添加空格
            if (i != words.length - 1) {
                result.append(" ");
            }
相关推荐
不爱吃炸鸡柳7 小时前
单链表专题(完整代码版)
数据结构·算法·链表
CylMK7 小时前
题解:AT_abc382_d [ABC382D] Keep Distance
算法
Dfreedom.8 小时前
计算机视觉全景图
人工智能·算法·计算机视觉·图像算法
Morwit8 小时前
【力扣hot100】 1. 两数之和
数据结构·c++·算法·leetcode·职场和发展
py有趣8 小时前
力扣热门100题之岛屿的数量(DFS/BFS经典题)
leetcode·深度优先·宽度优先
无小道9 小时前
算法——暴力+优化
算法·优化·暴力
Free Tester9 小时前
如何判断 LeakCanary 报告的严重程度
java·jvm·算法
zyq99101_19 小时前
DFS算法实战:经典例题代码解析
python·算法·蓝桥杯·深度优先
智者知已应修善业9 小时前
【51单片机单按键切换广告屏】2023-5-17
c++·经验分享·笔记·算法·51单片机
广州灵眸科技有限公司9 小时前
为RK3588注入澎湃算力:RK1820 AI加速卡完整适配与评测指南
linux·网络·人工智能·物联网·算法