栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

java 剑指offer之[数据结构 简单]JZ50 第一个只出现一次的字符

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

java 剑指offer之[数据结构 简单]JZ50 第一个只出现一次的字符

题目的链接在这里:https://www.nowcoder.com/practice/1c82e8cf713b4bbeb2a5b31cf5b0417c

目录
  • 题目大意
  • 一、示意图
  • 二、解题思路
    • hashMap
    • String方法


题目大意 在一个长为 字符串中找到第一个只出现一次的字符,并返回它的位置, 如果没有则返回 -1(需要区分大小写).(从0开始计数)

数据范围:0 le n le 100000≤n≤10000,且字符串只有字母组成。
要求:空间复杂度 O(n)O(n),时间复杂度 O(n)O(n)


一、示意图

二、解题思路
hashMap String方法
hashMap

代码如下:

import java.util.*;
public class Solution {
        public int FirstNotRepeatingChar(String str) {
                //找到第一个只出现一次的字符 那就直接用HashMap来遍历
                HashMap hashMap=new HashMap<>();
                for(char s:str.toCharArray()){
                        if(hashMap.containsKey(s)){
                                //说明这个存在
                                int value=hashMap.get(s);
                                value++;
                                hashMap.put(s,value);
                        }
                        else{
                                //那就放进去
                                hashMap.put(s,1);
                        }
                }
                //然后返回第一个等于1的值
                //直接通过这个遍历好了
                char[] chars = str.toCharArray();
                for(int i=0;i 

String方法

代码如下:

import java.util.*;
public class Solution {
        public int FirstNotRepeatingChar(String str) {
                //直接遍历 第一次出现的地方和最后一次出现的地方一致即可
                for(int i=0;i 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/343146.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号