返回顶部
首页 > 资讯 > 后端开发 > JAVA >java实现查找第一个只出现一次的字符
  • 133
分享到

java实现查找第一个只出现一次的字符

java教程java第一次一次字符 2016-06-10 09:06:12 133人浏览 才女
摘要

问题:在一个字符串(0

问题:

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

相关视频教程推荐:java在线教程

解决思路:

题目要求很明确,就是遍历字符串,并且给字符计数,计数之后,找到计数为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快速入门

--结束END--

本文标题: java实现查找第一个只出现一次的字符

本文链接: https://lsjlt.com/news/3048.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作