在一个字符串中找到第一个仅仅出现一次的字符。

题目:在一个字符串中找到第一个仅仅出现一次的字符。如输入abaccdeff,则输出b。 分析:这道题是2006年google的一道笔试题。



以下给我的解法,採用linkedhashmap的有序,就可以实现


private void getOne(String str){
			
			LinkedHashMap<String, Object> linked=new LinkedHashMap<String, Object>();
			
			for (char charstr : str.toCharArray()) {
				String strVal=String.valueOf(charstr);
				if(linked.containsKey(strVal)){// 假设包括该key,则直接移除
					linked.remove(strVal);
				}else{
					//假设没有则加入
					linked.put(strVal, null);
				}
				
			}
			
			for (Iterator<String> it=linked.keySet().iterator();it.hasNext();){
				System.out.println(it.next());
			}
			
		}



posted @ 2015-02-03 10:02  blfshiye  阅读(179)  评论(0编辑  收藏  举报