0
我在一个字符串,如下找到第一个非重复字符工作找到第一个非重复字符的字符值:搞清楚在一个字符串
package com.tk.practice;
import java.util.HashMap;
import java.util.Map;
public class FirstNonRepeatedCharacter {
public static void main(String[] args) {
String str = "stress";
char[] ch = str.toCharArray();
int length = ch.length;
//System.out.println(length);
for(int i = 0; i<length;i++){
char character = str.charAt(i);
Map<Character, Integer> map = new HashMap<Character,Integer>();
if(map.containsKey(character)){
map.put(character, map.get(character)+1);
}
else{
map.put(character, 1);
}
for(Map.Entry<Character, Integer> m : map.entrySet()){
//Integer ill = m.getValue();
//Character ch1 = m.getKey();
//if(ill == 1){
System.out.println("Key: "+m.getKey()+" Value: "+m.getValue());
//}
}
}
}}
这只是印刷价值为每个角色的权利现在。但我想了解以下行一两件事:
if(map.containsKey(character)){
map.put(character, map.get(character)+1);
}
因为,在value
是一个整数值,那么为什么map.get(character)
没有抛出任何错误的map.get(character)
要检索的性格吧,而不是值?我正在考虑使用getKey()
,但是会引发错误。如果我误解了某些东西,请解释我。