leetcode-07-[344]反转字符串[541]反转字符串II[卡码网54]替换数字

一、[344]反转字符串

java 复制代码
class Solution {
    public void reverseString(char[] s) {
        int left=0,right=s.length-1;
        while(left<right){
            char tmp=s[left];
            s[left]=s[right];
            s[right]=tmp;
            left++;
            right--;
        }
    }
}

二、[541]反转字符串II

重点:

1、字符数组转String 一般 new String(ch);

Arrays.toString(ch); 将数组转换成String类型输出的

输出示例:

b,a,c,d,f,e,g

会出现错误

java 复制代码
class Solution {
    public String reverseStr(String s, int k) {
        char[] ch = s.toCharArray();
        for(int i=0;i< ch.length;i=i+2*k){
            int start=i;
            int end = Math.min(ch.length - 1, k - 1 + start);
            while(start<end){
                char tmp=ch[start];
                ch[start]=ch[end];
                ch[end]=tmp;
                start++;
                end--;
            }
        }
        //将数组转换成String类型输出的
        //Arrays.toString(ch);
        //[b,a,c,d,f,e,g]
        return new String(ch);
    }
}

三、[卡码网54]替换数字

重点:String 不可变

转为字符数组

或者用StringBuffer 、StringBuilder

java 复制代码
import java.util.*;
//类名必须为Main
public class Main{
	public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        String s = scanner.next();
        String res = replaceDigits(s);
        System.out.println(res);
        scanner.close();
    }
    public static String replaceDigits(String s) {
        char[] ch = s.toCharArray();
        int count=0;
        for(int i=0;i<s.length();i++){
            if(Character.isDigit(ch[i])){
                count++;
            }
        }
        int newLength=s.length()+5*count;
        char[] newCh=new char[newLength];
        for(int i=0;i<s.length();i++){
            newCh[i]=ch[i];
        }
        int j=newLength-1;
        for(int i=s.length()-1;i>=0;i--){
            if(!Character.isDigit(newCh[i])){
                newCh[j]=newCh[i];
                j--;
            }else{
                //number
                newCh[j--]='r';
                newCh[j--]='e';
                newCh[j--]='b';
                newCh[j--]='m';
                newCh[j--]='u';
                newCh[j--]='n';
            }
        }
        return new String(newCh);
    }
}
相关推荐
短剑重铸之日2 分钟前
《设计模式》第十一篇:总结
java·后端·设计模式·总结
艾莉丝努力练剑6 分钟前
【Linux:文件】Ext系列文件系统(初阶)
大数据·linux·运维·服务器·c++·人工智能·算法
若鱼191924 分钟前
SpringBoot4.0新特性-Observability让生产环境更易于观测
java·spring
觉醒大王33 分钟前
强女思维:着急,是贪欲外显的相。
java·论文阅读·笔记·深度学习·学习·自然语言处理·学习方法
偷吃的耗子37 分钟前
【CNN算法理解】:CNN平移不变性详解:数学原理与实例
人工智能·算法·cnn
努力学编程呀(๑•ี_เ•ี๑)41 分钟前
【在 IntelliJ IDEA 中切换项目 JDK 版本】
java·开发语言·intellij-idea
码农小卡拉1 小时前
深入解析Spring Boot文件加载顺序与加载方式
java·数据库·spring boot
向上的车轮1 小时前
为什么.NET(C#)转 Java 开发时常常在“吐槽”Java:checked exception
java·c#·.net
Dragon Wu1 小时前
Spring Security Oauth2.1 授权码模式实现前后端分离的方案
java·spring boot·后端·spring cloud·springboot·springcloud
跳动的梦想家h1 小时前
环境配置 + AI 提效双管齐下
java·vue.js·spring