(1)如何在字符串中获取不同的字符及其数量?
public static void main(String[] args) {
printDistinctCharsWithCount("jasonn");
printDistinctCharsWithCountByLambda("jason小蜗牛");
}
/**
* 实现思路:
* 1、将输入的字符串转换成字符数组
* 2、遍历这个字符数组,将这个字符放入map中,并用字符作为key,字符出现的次数作为value
* 3、如果key不存在则说明出现的次数为1,此后将这个字符的原来的value加上1即可。
*
* @param input 输入的字符串
*/
private static void printDistinctCharsWithCount(String input) {
Map<Character, Integer> charsWithCountMap = new LinkedHashMap<>();
for (char c : input.toCharArray()) {
Integer oldValue = charsWithCountMap.get(c);
int newValue = (oldValue == null) ? 1 : Integer.sum(oldValue, 1);
charsWithCountMap.put(c, newValue);
}
System.out.println(charsWithCountMap);
}
// 采用lambda实现
private static void printDistinctCharsWithCountByLambda(String input) {
Map<Character, Integer> charsWithCountMap = new LinkedHashMap<>();
for (char c : input.toCharArray()) {
charsWithCountMap.merge(c, 1, Integer::sum);
}
System.out.println("采用lambda实现:" + charsWithCountMap);
}
// merge()方法是java 8出现的新特性,第一个参数为key,第二个参数为value,第三个参数为一个BiFunction函数式接口类型,
// 它的特点是把判断和计算整合成为了一步操作。
// 含义是如果key不存在则将key和value put到map中,如果key存在,则根据BiFunction计算的结果,重新覆盖原来的value值。
(2)如何反转字符串?
public static void main(String[] args) {
reveseChar("jasonn");
}
/**
* 实现思路:
* 使用StringBuilder的reverse()即可
*
* @param input 输入的字符串
*/
private static void reveseChar(String input) {
StringBuilder stringBuilder = new StringBuilder();
String str = stringBuilder.append(input).reverse().toString();
System.out.println(str);
}
(3)如何判断一个字符串是前后对称的?
public static void main(String[] args) {
checkPalindromeString("jason小蜗牛");
checkPalindromeString("jason小蜗牛 牛蜗小nosaj");
}
/**
* 实现思路:
* 1、将字符串从中间分成两部分
* 2、进行判断第一个与最后一个,第二与倒数第二个是否相同,如果不同立马break
*
* 需要注意如下三点:
* 1、for 循环的下标从 0 开始,到 length/2 结束
* 2、下标 i 和 length-i-1 是对称的
* 3、一旦 false 就 break
*
* @param input 输入的字符
*/
private static void checkPalindromeString(String input) {
boolean result = true;
int length = input.length();
for (int i = 0; i < length / 2; i++) {
if (input.charAt(i) != input.charAt(length - i - 1)) {
result = false;
break;
}
}
System.out.println(input + " 对称吗? " + result);
}
(4)如何删除所有出现的指定字符?
public static void main(String[] args) {
removeCharFromString("jason小蜗牛", 'n');
}
/**
* 实现思路:
* String类没有提供remove操作,但是提供了replaceAll方法
* 因此只需要将出现的字符替换为空白即可
*
* @param input 输入的字符串
* @param c 需要删除的指定字符
*/
private static void removeCharFromString(String input, char c) {
String result = input.replaceAll(String.valueOf(c), "");
System.out.println(result);
}
(5)如何统计字符串中的单词数?
public static void main(String[] args) {
countNumberOfWords("My name is java");
}
/**
* 实现思路:
* 1、去掉首尾空格,
* 2、然后采用split方法,使用正则表达式,
* 3、split的结果是数组,这个数组的长度就是单词个数
*
* @param line 输入的一行句子
*/
private static void countNumberOfWords(String line) {
String trimmedLine = line.trim();
int count = trimmedLine.isEmpty() ? 0 : trimmedLine.split("\s+").length;
System.out.println(count);
}
(6)如何判断一个字符串包含了另外一个字符串?
public static void main(String[] args) {
String s1 = "jason小蜗牛";
String s2 = "j";
System.out.println(s1.contains(s2));
}
// contains方法源码
public boolean contains(CharSequence s) {
return indexOf(s.toString()) > -1;
}
(7)如何在不用第三个变量的情况下交换两个字符串?
public static void main(String[] args) {
String s1 = "jason";
String s2 = "小蜗牛";
s1 = s1.concat(s2);
s2 = s1.substring(0, s1.length() - s2.length());
s1 = s1.substring(s2.length());
System.out.println("s1=" + s1);
System.out.println("s2=" + s2);
}
(8)如何从字符串中找出第一个不重复的字符?
public static void main(String[] args) {
System.out.println(printFirstNonRepeatingChar("jaasjoon小蜗牛"));
}
/**
* @param string 输入的字符串
* @return 返回结果字符
*/
private static Character printFirstNonRepeatingChar(String string) {
// 将字符串转换成字符数组
char[] chars = string.toCharArray();
// 声明一个字符list
List<Character> characterList = new ArrayList<>();
// 外层循环遍历chars数组
for (int i = 0; i < chars.length; i++) {
char c = chars[i];
// 如果characterList中已存在字符c则结束当前循环
if (characterList.contains(c)) {
continue;
}
// 从字符c的下一个字符开始遍历,如果后面的字符有与字符c相同的则加入到characterList中,结束这个循环
// 如果从字符c的下一个字符开始直到最后一个字符都没有与此字符相同的,则此字符即为第一个不重复的字符
for (int j = i + 1; j < chars.length; j++) {
if (c == chars[j]) {
characterList.add(c);
break;
} else if (j == chars.length - 1) {
return c;
}
}
}
return null;
}
(9)如何检查字符串中只包含数字?
public static void main(String[] args) {
digitsOnlyString("jaasjoon小蜗牛");
digitsOnlyString("123479");
}
/**
* 使用正则表达式进行判断是否只包含数字
*
* @param string 输入的字符串
*/
private static void digitsOnlyString(String string) {
if (string.matches("\d+")) {
System.out.println("只包含数字的字符串:" + string);
} else {
System.out.println("此字符包含其他字符:" + string);
}
}