Leetcode541151中,如何高效处理字符串与char数组及StringBuffer操作?

2026-05-17 04:342阅读0评论SEO教程
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1034个文字,预计阅读时间需要5分钟。

Leetcode541/151中,如何高效处理字符串与char数组及StringBuffer操作?

在常规情况下,当需要删除字符或反转字符串时,需要将String转换为char数组或使用StringBuffer和String。以下是一个简化的示例:

javaString str=HelloWorld;char[] charArray=str.toCharArray(); // 将String转换为char数组StringBuffer sb=new StringBuffer(str); // 使用StringBuffer

// 删除字符charArray[0]='\0'; // 删除第一个字符

// 反转字符串sb.reverse();

// 输出结果System.out.println(删除字符后的字符串: + new String(charArray));System.out.println(反转后的字符串: + sb.toString());

String与char数组与StringBuffer

Leetcode541/151中,如何高效处理字符串与char数组及StringBuffer操作?

  • 通常情况下遇到删除字符或者反转字符串时需要将String转为char数组或者StringBuffer

String与char数组

  • char [] stringArr = string.toCharArray();
  • char[] charArray = {'P','A','N','K','A','J'}; String str = new String(charArray);

StringBuffer常用方法

  • StringBuffer stb=new StringBuffer();//里面也能放char数组或者string
  • stb.appdend(char c)
  • stb.insert(int index, char c)
  • stb.delete(int start,int edn)
  • stb.deleteChatAt(int index)
  • stb.length()
  • stb.replace(int start, int end, String str)
  • stb.reverse()

Leetcode541-反转字符串二

  • 给定一个字符串 s 和一个整数 k,从字符串开头算起,每计数至 2k 个字符,就反转这 2k 字符中的前 k 个字符。
  • 如果剩余字符少于 k 个,则将剩余字符全部反转
  • 如果剩余字符小于 2k 但大于或等于 k 个,则反转前 k 个字符,其余字符保持原样
  • 输入:s = "abcdefg", k = 2
  • 输出:"bacdfeg"

public String reverseStr1(String s, int k) { char[] c=s.toCharArray(); for(int i=0;i<s.length();i=i+2*k){ if((i+k)<=s.length()){ reverse(c,i,i+k-1); }else{ int len=s.length()-i; reverse(c,i,i+len-1); } } return new String(c); } public static void reverse(char[] c,int left,int right){ while (left<right){ char temp = c[left]; c[left]=c[right]; c[right]=temp; left++; right--; } } public String reverseStr2(String s, int k) { StringBuffer res=new StringBuffer(); for(int i=0;i<s.length();i=i+2*k){ if((i+k)<s.length()){ StringBuffer temp1=new StringBuffer(s.substring(i,i+k)); temp1.reverse(); res.append(temp1); if((i+2*k)<s.length()){ res.append(s.substring(i+k,i+2*k)); }else{ int len=s.length()-(i+k); res.append(s.substring(i+k,i+k+len)); } }else{ int len=s.length()-i; StringBuffer temp2=new StringBuffer(s.substring(i,i+len)); temp2.reverse(); res.append(temp2); } } return new String(res); }

Leetcode151-颠倒字符串中的单词

  • 给你一个字符串 s ,颠倒字符串中 单词 的顺序。
  • 单词 是由非空格字符组成的字符串。s 中使用至少一个空格将字符串中的 单词 分隔开。
  • 返回 单词 顺序颠倒且 单词 之间用单个空格连接的结果字符串。
  • 注意:输入字符串 s中可能会存在前导空格、尾随空格或者单词间的多个空格。返回的结果字符串中,单词间应当仅用单个空格分隔,且不包含任何额外的空格。
  • 输入:s = "the sky is blue"
  • 输出:"blue is sky the"

//string的trim以及+,charat要熟练使用 public class L151 { public static String reverseWords1(String s) { String trim = s.trim(); String result = new String(); String temp = new String(); for (int i = 0; i < trim.length(); i++) { char c = trim.charAt(i); if (c == ' ') {//遇到新的单词了 result = temp + " " + result; temp = new String(); while (i + 1 < trim.length() && trim.charAt(i + 1) == ' ') { i++; } } else { temp = temp + c; } } result = temp + " " + result; result = result.trim(); return result; } //方法二使用StringBuffer 效率更高 public String reverseWords2(String s) { StringBuffer res=new StringBuffer(); LinkedList<Character> stack=new LinkedList(); for(int i=s.length()-1;i>=0;i--){ Character tempChar=s.charAt(i); if(tempChar!=' '){ stack.addFirst(tempChar); }else{ boolean flag=false; while(!stack.isEmpty()){ flag=true; res.append(stack.removeFirst()); } if(flag==true){ res.append(" "); //只有加过字母才需要加空格 //但是这里无法筛选调最后的空格 //一种方式是和上面一样使用trim //另一种方法是在下面对其特殊处理 } } } //最后栈中的元素特殊处理 while(!stack.isEmpty()){ res.append(stack.removeFirst()); } if (res.charAt(res.length() - 1)==' ') { res.deleteCharAt(res.length() - 1); } return new String(res); } public static void main(String[] args) { String s = "aa bb cc"; String res = reverseWords1(s); System.out.println(res); } }

本文共计1034个文字,预计阅读时间需要5分钟。

Leetcode541/151中,如何高效处理字符串与char数组及StringBuffer操作?

在常规情况下,当需要删除字符或反转字符串时,需要将String转换为char数组或使用StringBuffer和String。以下是一个简化的示例:

javaString str=HelloWorld;char[] charArray=str.toCharArray(); // 将String转换为char数组StringBuffer sb=new StringBuffer(str); // 使用StringBuffer

// 删除字符charArray[0]='\0'; // 删除第一个字符

// 反转字符串sb.reverse();

// 输出结果System.out.println(删除字符后的字符串: + new String(charArray));System.out.println(反转后的字符串: + sb.toString());

String与char数组与StringBuffer

Leetcode541/151中,如何高效处理字符串与char数组及StringBuffer操作?

  • 通常情况下遇到删除字符或者反转字符串时需要将String转为char数组或者StringBuffer

String与char数组

  • char [] stringArr = string.toCharArray();
  • char[] charArray = {'P','A','N','K','A','J'}; String str = new String(charArray);

StringBuffer常用方法

  • StringBuffer stb=new StringBuffer();//里面也能放char数组或者string
  • stb.appdend(char c)
  • stb.insert(int index, char c)
  • stb.delete(int start,int edn)
  • stb.deleteChatAt(int index)
  • stb.length()
  • stb.replace(int start, int end, String str)
  • stb.reverse()

Leetcode541-反转字符串二

  • 给定一个字符串 s 和一个整数 k,从字符串开头算起,每计数至 2k 个字符,就反转这 2k 字符中的前 k 个字符。
  • 如果剩余字符少于 k 个,则将剩余字符全部反转
  • 如果剩余字符小于 2k 但大于或等于 k 个,则反转前 k 个字符,其余字符保持原样
  • 输入:s = "abcdefg", k = 2
  • 输出:"bacdfeg"

public String reverseStr1(String s, int k) { char[] c=s.toCharArray(); for(int i=0;i<s.length();i=i+2*k){ if((i+k)<=s.length()){ reverse(c,i,i+k-1); }else{ int len=s.length()-i; reverse(c,i,i+len-1); } } return new String(c); } public static void reverse(char[] c,int left,int right){ while (left<right){ char temp = c[left]; c[left]=c[right]; c[right]=temp; left++; right--; } } public String reverseStr2(String s, int k) { StringBuffer res=new StringBuffer(); for(int i=0;i<s.length();i=i+2*k){ if((i+k)<s.length()){ StringBuffer temp1=new StringBuffer(s.substring(i,i+k)); temp1.reverse(); res.append(temp1); if((i+2*k)<s.length()){ res.append(s.substring(i+k,i+2*k)); }else{ int len=s.length()-(i+k); res.append(s.substring(i+k,i+k+len)); } }else{ int len=s.length()-i; StringBuffer temp2=new StringBuffer(s.substring(i,i+len)); temp2.reverse(); res.append(temp2); } } return new String(res); }

Leetcode151-颠倒字符串中的单词

  • 给你一个字符串 s ,颠倒字符串中 单词 的顺序。
  • 单词 是由非空格字符组成的字符串。s 中使用至少一个空格将字符串中的 单词 分隔开。
  • 返回 单词 顺序颠倒且 单词 之间用单个空格连接的结果字符串。
  • 注意:输入字符串 s中可能会存在前导空格、尾随空格或者单词间的多个空格。返回的结果字符串中,单词间应当仅用单个空格分隔,且不包含任何额外的空格。
  • 输入:s = "the sky is blue"
  • 输出:"blue is sky the"

//string的trim以及+,charat要熟练使用 public class L151 { public static String reverseWords1(String s) { String trim = s.trim(); String result = new String(); String temp = new String(); for (int i = 0; i < trim.length(); i++) { char c = trim.charAt(i); if (c == ' ') {//遇到新的单词了 result = temp + " " + result; temp = new String(); while (i + 1 < trim.length() && trim.charAt(i + 1) == ' ') { i++; } } else { temp = temp + c; } } result = temp + " " + result; result = result.trim(); return result; } //方法二使用StringBuffer 效率更高 public String reverseWords2(String s) { StringBuffer res=new StringBuffer(); LinkedList<Character> stack=new LinkedList(); for(int i=s.length()-1;i>=0;i--){ Character tempChar=s.charAt(i); if(tempChar!=' '){ stack.addFirst(tempChar); }else{ boolean flag=false; while(!stack.isEmpty()){ flag=true; res.append(stack.removeFirst()); } if(flag==true){ res.append(" "); //只有加过字母才需要加空格 //但是这里无法筛选调最后的空格 //一种方式是和上面一样使用trim //另一种方法是在下面对其特殊处理 } } } //最后栈中的元素特殊处理 while(!stack.isEmpty()){ res.append(stack.removeFirst()); } if (res.charAt(res.length() - 1)==' ') { res.deleteCharAt(res.length() - 1); } return new String(res); } public static void main(String[] args) { String s = "aa bb cc"; String res = reverseWords1(s); System.out.println(res); } }