java怎么获取字符串中只出现一次的字符

问题:

创新互联建站是一家专业提供扬中企业网站建设,专注与成都网站制作、成都做网站、外贸营销网站建设H5开发、小程序制作等业务。10年已为扬中众多企业、政府机构等服务。创新互联专业网站制作公司优惠进行中。

在一个字符串(0<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置, 如果没有则返回 -1(需要区分大小写)

解决思路:

题目要求很明确,就是遍历字符串,并且给字符计数,计数之后,找到计数为1的字符即可。很明显这需要用到hashmap,key就是字符串中的各个字符,而value就是这个字符在字符串中出现的次数。

代码如下:

import java.util.LinkedHashMap;
public class Solution {
    public int FirstNotRepeatingChar(String str) {
        int len = str.length();
        LinkedHashMap map = new LinkedHashMap<>();
        for (int i = 0; i < len; i++) {
            char c = str.charAt(i);
            Integer val = map.get(c);
            map.merge(c, 1, (oldValue, newValue) -> oldValue + newValue);
        }
        Character resultKey = null;
        for (Character c : map.keySet()){
            if (map.get(c) == 1){
                resultKey = c;
                break;
            }
        }
        for (int i = 0 ;i < len; i++){
            if (str.charAt(i) == resultKey){
                return i;
            }
        }        
       return -1;
    }
}

以上就是java实现查找第一个只出现一次的字符的详细内容,更多请关注创新互联其它相关文章!


网页标题:java怎么获取字符串中只出现一次的字符
标题URL:http://bzwzjz.com/article/gjsgcj.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 成都网站制作 商城网站建设 成都网站设计 成都网站设计 成都网站设计 成都网站设计 成都网站建设公司 阿坝网站设计 重庆网站设计 成都网站设计公司 定制级高端网站建设 盐亭网站设计 专业网站设计 网站制作公司 网站建设公司 成都网站建设 手机网站制作设计 四川成都网站建设 重庆企业网站建设 网站设计制作 网站建设 攀枝花网站设计