【Leetcode541/151之String与char数组与StringBuffer】String与char数组与StringBuffer
- 通常情况下遇到删除字符或者反转字符串时需要将String转为char数组或者StringBuffer
- char [] stringArr = string.toCharArray();
- char[] charArray = {'P','A','N','K','A','J'}; String str = new String(charArray);
- 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()
- 给定一个字符串 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
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 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);
}
}