1.获取一个字符串在另一个字符串中出现的次数。
比如:获取"ab"在"abdsfsafkhjkfaabddfskjab"中出现的次数
package com.commonClass;
import org.junit.Test;
public class StringDemo1 {
public int getCount(String mainStr,String subStr){
int mainLength = mainStr.length();
int subLength = subStr.length();
int count = 0;
int index = 0;
if (mainLength>=subLength){
while ((index = mainStr.indexOf(subStr,index)) != -1){
count++;
index += subLength;
}
}
return count;
}
@Test
public void test1(){
String mainStr = "abdsfsafkhjkfaabddfskjab";
String subStr = "ab";
System.out.println(getCount(mainStr,subStr));
}
}
2.将字符串进行翻转。将字符串指定部分进行翻转,比如”abcdefg“反转为"abfedcg"
package com.commonClass;
import org.junit.Test;
public class StringDemo2 {
public String reverse1(String str, int startIndex, int endIndex){
if (str != null){
char[] arr = str.toCharArray();
for (int x = startIndex,y = endIndex;x<y;x++,y--){
char temp = arr[x];
arr[x] = arr[y];
arr[y] = temp;
}
return new String(arr);
}
return null;
}
public String reverse2(String str, int startIndex, int endIndex){
if (str != null){
String reverseStr = str.substring(0,startIndex);
for (int i = endIndex;i>=startIndex;i--) {
reverseStr += str.charAt(i);
}
reverseStr += str.substring(endIndex+1);
return reverseStr;
}
return null;
}
public String reverse3(String str, int startIndex, int endIndex){
if (str != null){
StringBuilder builder = new StringBuilder(str.length());
builder.append(str.substring(0,startIndex));
for (int i = endIndex;i>=startIndex;i--) {
builder.append(str.charAt(i));
}
builder.append(str.substring(endIndex+1));
return builder.toString();
}
return null;
}
@Test
public void test1(){
String str1 = "abcdefg";
String str = new String(reverse1(str1,2,5));
System.out.println(str);
String str2 = new String(reverse2(str1,2,4));
System.out.println(str2);
String str3 = new String(reverse2(str1,2,3));
System.out.println(str3);
}
}
3.获取两个字符串中的最大相同字串(只有一个),比如:str1 = “riuetiejknvdasdfgmbnxjhh”,str2 = “asdfghghjgh”
提示:将短的那个串进行长度依次递减的子串与较长的串比较。
package com.commonClass;
import org.junit.Test;
public class StringDemo3 {
public String getMaxSameString(String str1, String str2){
if (str1!=null&&str2!=null){
String maxStr = (str1.length() >= str2.length()) ? str1 : str2;
String minStr = (str1.length() < str2.length()) ? str1 : str2;
int length = minStr.length();
for (int i = 0; i < length; i++) {
for (int x = 0, y = length - i; y <= length; x++, y++) {
String subStr = minStr.substring(x, y);
if (maxStr.contains(subStr)) {
return subStr;
}
}
}
}
return null;
}
@Test
public void test1(){
String str1 = "riuetiejknvdasdfg1mbnxjhh";
String str2 = "asdfg1hghjgh";
System.out.println(getMaxSameString(str1,str2));
}
}