1、字符串转化(压缩) “aabbccdaa” -> “a2b2c2d1a2”
public class TestDemo1 {
public static String stringCompress(String str){
StringBuilder sb=new StringBuilder();
char[] c=str.toCharArray();
int count=1;
int i=0;
for(i=0;i<str.length()-1;i++){
if(str.charAt(i)==str.charAt(i+1)){
count++;
}
else{
sb=sb.append(c[i]).append(count);
count=1;
}
}
sb=sb.append(c[i]).append(count);
return sb.toString();
}
public static void main(String[] args) {
System.out.println(stringCompress("aabbccdaa"));
}
}
2、统计字符串中数字个数
//如:“abc21b416u” ===> 输出5
public class TestDemo2 {
public static int isNumeric(String str){
int count=0;
char[] c=str.toCharArray();
for(int i=0;i<str.length();i++){
if(c[i]<'9'&&c[i]>'0'){
count++;
}
}
return count;
}
public static void main(String[] args) {
System.out.println("请输入一个字符串");
Scanner scanner =new Scanner(System.in);
String str=scanner.next();
System.out.println(isNumeric(str));
}
}
3、题目:=====i am biter 逆置为:biter am i
public class TestDemo3 {
public static String reverseSentence(String str){
int a=0;
int b=0;
int i=0;
StringBuilder sb=new StringBuilder();
char[] c=str.toCharArray();
for(i=0;i<c.length;i++) {
if (str.charAt(i) == ' ') {
a = i;
break;
}
}
for(int j=i+1;j<c.length;j++){
if(str.charAt(j)==' '){
b=j;
break;
}
}
String str1=str.substring(0,a);//提取第一个空格之前的单词
String str2=str.substring(a,b);//提取第一个与第二个空格之间的单词
String str3=str.substring(b);//提取第二个空格之后的单词
sb=sb.append(str3).append(str2).append(' ').append(str1);
return sb.toString();
}
public static void main(String[] args) {
String str="i am boy";
System.out.println(reverseSentence(str));
}
}
4、将一个数组从左开始第几位之前的进行旋转:左旋数组
如:将"abcdef"第2位之前(a为0号位置)进行旋转----》“cdefab”
import java.util.Scanner;
public class TestDemo4 {
public static void leftRotateString(String str,int n){
String str1=str.substring(0,n);
String str2=str.substring(n);
String t;
t=str1;
str1=str2;
str2=t;
System.out.println(str1+str2);
}
public static void main(String[] args) {
String str="abcdef";
System.out.println("请输入你要在第几位对abcdef进行左旋:");
Scanner scanner=new Scanner(System.in);
int n=scanner.nextInt();
leftRotateString(str,n);
}
}