第一个只出现一次的字符

在一个字符串(1<=字符串长度<=10000,全部由大小写字母组成)中找到第一个只出现一次的字符,并返回它的位置

import java.util.LinkedHashMap;
// use linkedhashmap to keep the order
public class Solution {
     public int FirstNotRepeatingChar(String str) {
         LinkedHashMap <Character, Integer> map =  new LinkedHashMap<Character, Integer>();
         for ( int i= 0 ;i<str.length();i++){
             if (map.containsKey(str.charAt(i))){
                 int time = map.get(str.charAt(i));
                 map.put(str.charAt(i), ++time);
             }
             else {
                 map.put(str.charAt(i),  1 );
             }
         }
         int pos = - 1 ;  
         int i= 0 ;
         for (;i<str.length();i++){
             char c = str.charAt(i);
             if (map.get(c) ==  1 ) {
                 return i;
             }
         }
         return pos;
     }
}
作为java程序员来说,这题相比推荐的ac答案,我更喜欢这个,因为使用到了散列表,感觉更像java程序员写出来的。虽然我自己写的时候用的HashMap,这楼选择LinkedhashMap(这个题查找比较多,用Linked会影响效率吧)我有点疑惑外,希望java程序员不要采用推荐的那种,反正要用到的就是键值对查找,干脆用类库不就好了:)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值