leetcode-08-[151]翻转字符串里的单词[卡码网55]右旋转字符串

一、[151]翻转字符串里的单词

重点:见注释

java 复制代码
class Solution {
    public String reverseWords(String s) {
        //1、移除多余的空格
        StringBuilder stringBuilder = removeSpace(s);
        //2、反转整个字符串
        reverse(stringBuilder,0,stringBuilder.length()-1);
        //3、反转每个单词
        reverseEachWord(stringBuilder);
        return stringBuilder.toString();
    }
    StringBuilder removeSpace(String s){
        StringBuilder stringBuilder=new StringBuilder();
        int left=0,right=s.length()-1;
        while(s.charAt(left)==' '){
            left++;
        }
        while(s.charAt(right)==' '){
            right--;
        }
        for(int i=left;i<right+1;i++){
            if(s.charAt(i)!=' '){
                stringBuilder.append(s.charAt(i));
            }else if(stringBuilder.charAt(stringBuilder.length()-1)!=' '){
                //若结束位置不为空格,则加个空格,否则什么也不做
                stringBuilder.append(s.charAt(i));
            }
        }
        return stringBuilder;
    }
    //设置开始结束的标记
    void reverse(StringBuilder stringBuilder,int left,int right){
        while(left<right){
            char tmp = stringBuilder.charAt(left);
            //设置值setCharAt
            stringBuilder.setCharAt(left,stringBuilder.charAt(right));
            stringBuilder.setCharAt(right,tmp);
            left++;
            right--;
        }
    }
    //注意一下
    void reverseEachWord(StringBuilder stringBuilder){
        int left=0,right=1;
        int n=stringBuilder.length();
        while(left<n){
            while(right<n&&stringBuilder.charAt(right)!=' '){
                right++;
            }
            reverse(stringBuilder,left,right-1);
            left=right+1;
            right=left+1;
        }
    }

}

二、[卡码网55]右旋转字符串

重点:技巧

反转三次

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

public class Main{
    public static void main (String[] args) {
        Scanner in=new Scanner(System.in);
        int n=Integer.parseInt(in.nextLine());
        String s=in.nextLine();
        int len=s.length();
        char[] chars=s.toCharArray();
        reverse(chars,0,len-1);
        reverse(chars,0,n-1);
        reverse(chars,n,len-1);
        System.out.println(chars);
    }
    public static void reverse(char[] ch,int start,int end){
        while(start<end){
            char tmp=ch[start];
            ch[start]=ch[end];
            ch[end]=tmp;
            start++;
            end--;
        }
    }
}
相关推荐
松☆2 分钟前
CANN与大模型推理:在边缘端高效运行7B参数语言模型的实践指南
人工智能·算法·语言模型
_F_y4 分钟前
C++重点知识总结
java·jvm·c++
打工的小王5 分钟前
Spring Boot(三)Spring Boot整合SpringMVC
java·spring boot·后端
毕设源码-赖学姐7 分钟前
【开题答辩全过程】以 高校体育场馆管理系统为例,包含答辩的问题和答案
java·spring boot
我真会写代码8 分钟前
SSM(指南一)---Maven项目管理从入门到精通|高质量实操指南
java·spring·tomcat·maven·ssm
vx_Biye_Design9 分钟前
【关注可免费领取源码】房屋出租系统的设计与实现--毕设附源码40805
java·spring boot·spring·spring cloud·servlet·eclipse·课程设计
java干货13 分钟前
为什么 “File 10“ 排在 “File 2“ 前面?解决文件名排序的终极算法:自然排序
开发语言·python·算法
DN金猿14 分钟前
接口路径正确,请求接口却提示404
java·tomcat
皮皮哎哟21 分钟前
数据结构:嵌入式常用排序与查找算法精讲
数据结构·算法·排序算法·二分查找·快速排序
程序员清洒30 分钟前
CANN模型剪枝:从敏感度感知到硬件稀疏加速的全链路压缩实战
算法·机器学习·剪枝