返回顶部
首页 > 资讯 > 后端开发 > GO >GoJava算法之字符串中第一个唯一字符详解
  • 943
分享到

GoJava算法之字符串中第一个唯一字符详解

2024-04-02 19:04:59 943人浏览 八月长安
摘要

目录字符串中第一个唯一字符方法一:哈希表(Java)方法二:队列(Go)字符串中第一个唯一字符 给定一个字符串 s ,找到 它的第一个不重复的字符,并返回它的索引

字符串中第一个唯一字符

给定一个字符串 s ,找到 它的第一个不重复的字符,并返回它的索引 。如果不存在,则返回 -1 。

  • 示例 1:

输入: s = "LeetCode"

输出: 0

  • 示例 2:

输入: s = "loveleetcode"

输出: 2

  • 示例 3:

输入: s = "aabb"

输出: -1  

提示:

1 <= s.length <= 105

s 只包含小写字母

方法一:哈希表(Java)

在第一次遍历时,我们使用哈希映射统计出字符串中每个字符出现的次数。

在第二次遍历时,我们只要遍历到了一个只出现一次的字符,那么就返回它的索引,否则在遍历结束后返回 -1。

class Solution {
    public int firstUniqChar(String s) {
        Map<Character, Integer> frequency = new HashMap<Character, Integer>();
        for (int i = 0; i < s.length(); ++i) {
            char ch = s.charAt(i);
            frequency.put(ch, frequency.getOrDefault(ch, 0) + 1);
        }
        for (int i = 0; i < s.length(); ++i) {
            if (frequency.get(s.charAt(i)) == 1) {
                return i;
            }
        }
        return -1;
    }
}

n:字符串长度

Σ:字符集

时间复杂度:O(n)

空间复杂度:O(∣Σ∣)

方法二:队列(Go)

我们也可以借助队列找到第一个不重复的字符。队列具有「先进先出」的性质,因此很适合用来找出第一个满足某个条件的元素。

具体地,我们使用与方法二相同的哈希映射,并且使用一个额外的队列,按照顺序存储每一个字符以及它们第一次出现的位置。

当我们对字符串进行遍历时,设当前遍历到的字符为 c,如果 c 不在哈希映射中,我们就将 c 与它的索引作为一个二元组放入队尾

否则我们就需要检查队列中的元素是否都满足「只出现一次」的要求,即我们不断地根据哈希映射中存储的值(是否为 -1)选择弹出队首的元素,直到队首元素「真的」只出现了一次或者队列为空。

type pair struct {
    ch  byte
    pos int
}
func firstUniqChar(s string) int {
    n := len(s)
    pos := [26]int{}
    for i := range pos[:] {
        pos[i] = n
    }
    q := []pair{}
    for i := range s {
        ch := s[i] - 'a'
        if pos[ch] == n {
            pos[ch] = i
            q = append(q, pair{ch, i})
        } else {
            pos[ch] = n + 1
            for len(q) > 0 && pos[q[0].ch] == n+1 {
                q = q[1:]
            }
        }
    }
    if len(q) > 0 {
        return q[0].pos
    }
    return -1
}

n:字符串长度

Σ:字符集

时间复杂度:O(n)

空间复杂度:O(∣Σ∣)

以上就是Go Java算法之字符串中第一个唯一字符详解的详细内容,更多关于Go Java算法字符串唯一字符的资料请关注编程网其它相关文章!

您可能感兴趣的文档:

--结束END--

本文标题: GoJava算法之字符串中第一个唯一字符详解

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

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

猜你喜欢
  • GoJava算法之字符串中第一个唯一字符详解
    目录字符串中第一个唯一字符方法一:哈希表(Java)方法二:队列(Go)字符串中第一个唯一字符 给定一个字符串 s ,找到 它的第一个不重复的字符,并返回它的索引...
    99+
    2024-04-02
  • Python教程:字符串中的第一个唯一字符
    Python教程——字符串中的第一个唯一字符题目:给定一个字符串,找到它的第一个不重复的字符,并返回它的索引。如果不存在,则返回 -1。案例:s = "leetcode"返回 0.s&nbs...
    99+
    2023-06-02
  • GoJava算法之同构字符串示例详解
    目录同构字符串方法一:哈希表(Java)方法一:哈希表(Go)同构字符串 给定两个字符串 s 和 t ,判断它们是否是同构的。 如果 ...
    99+
    2024-04-02
  • GoJava算法之K个重复字符最长子串详解
    目录至少有K个重复字符的最长子串方法一:分治(Java)方法二:滑动窗口(go)至少有K个重复字符的最长子串 给你一个字符串 s 和一个整数 k ,请你找出 s 中的最长子串,&nb...
    99+
    2024-04-02
  • php如何替换字符串中第一个字符
    小编给大家分享一下php如何替换字符串中第一个字符,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!在PHP中,可以使用substr_replace()函数来替换字符...
    99+
    2023-06-15
  • php怎么求字符串的第一个字符
    4种方法:1、用“$字符串变量名[0]”语句;2、用substr()截取第一个字符,语法“substr(英文字符串,0,1)”;3、用mb_substr()截取第一个字符,语法“mb_substr(中...
    99+
    2022-08-16
    php字符串 php
  • php字符串怎么去除第一个字符
    两种去除方法:1、用substr()去除,只需要将该函数的第二个参数设置为1,第三个参数省略即可,语法“substr(字符串,1)”。2、用str_split()将字符串转为字符数组,用array_shift()删除字符...
    99+
    2022-08-08
    php php字符串
  • jquery如何删除字符串第一个字符
    这篇文章主要介绍jquery如何删除字符串第一个字符,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! 删除字符串第一个字符的方法:1、使用“$(select...
    99+
    2024-04-02
  • PHP怎么交换字符串中第一个和最后一个字符
    这篇文章主要讲解了“PHP怎么交换字符串中第一个和最后一个字符”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PHP怎么交换字符串中第一个和最后一个字符”吧!本文主题是“编写一个 PHP 程序...
    99+
    2023-06-20
  • javascript如何去掉字符串的第一个字符
    这篇文章将为大家详细讲解有关javascript如何去掉字符串的第一个字符,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 在javascrip...
    99+
    2024-04-02
  • PHP返回字符串第一个字符的?ASCII?值
    这篇文章将为大家详细讲解有关PHP返回字符串第一个字符的 ASCII 值,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。PHP 返回字符串第一个字符的 ASCII 值 引言 在 PHP 中,获取字符串第一个...
    99+
    2024-04-02
  • php字符串如何替换第一个字符后面的字符
    本文小编为大家详细介绍“php字符串如何替换第一个字符后面的字符”,内容详细,步骤清晰,细节处理妥当,希望这篇“php字符串如何替换第一个字符后面的字符”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。php中可用s...
    99+
    2023-06-30
  • php分割字符串怎么除去第一个字符
    本文操作环境:Windows10系统、PHP7.1版、Dell G3电脑。php分割字符串怎么除去第一个字符在php中,可以使用substr截取字符串函数实现删除字符串第一个字符。新建一个php文件,命名为test.php,用于讲解php如...
    99+
    2016-09-18
    PHP
  • php如何去掉字符串的第一个点字符
    去除步骤:1、使用stripos()函数获取第一个点字符“.”在字符串的出现位置,语法“stripos(字符串,".")”;2、使用substr_replace()函数根据获取的字符位置,将该点字符替换为空字符即可,语法...
    99+
    2022-08-15
    php php字符串
  • php分割字符串如何除去第一个字符
    这篇文章主要介绍“php分割字符串如何除去第一个字符”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“php分割字符串如何除去第一个字符”文章能帮助大家解决问题。在PHP中,可以利用substr...
    99+
    2023-06-29
  • php字符串如何替换第一个字符后面
    本篇内容介绍了“php字符串如何替换第一个字符后面”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在PHP中,字符串替换函数的基本格式为:st...
    99+
    2023-07-05
  • es6如何将字符串第一个字符替换为其他字符
    这篇文章主要讲解了“es6如何将字符串第一个字符替换为其他字符”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“es6如何将字符串第一个字符替换为其他字符”吧!...
    99+
    2024-04-02
  • java实现输出字符串中第一个出现不重复的字符详解
    java实现输出字符串中第一个出现不重复的字符详解比如:输入name输出n,输入teeter输出r,输入namename输出null 具体实现代码如下:import java.util.Scanner;public class Main{ ...
    99+
    2023-05-31
    java 字符串 ava
  • 一个字符串中的字符有多少个
    这篇文章给大家介绍一个字符串中的字符有多少个,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。依照Java的文档, Java中的字符内部是以UTF-16编码方式表示的,最小值是 \\u0000 (0),最大值是\\ufff...
    99+
    2023-06-16
  • 一个Java字符串中有多少个字符
    本篇内容主要讲解“一个Java字符串中有多少个字符”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“一个Java字符串中有多少个字符”吧!依照Java的文档, Java中的字符内部是以UTF-16编...
    99+
    2023-06-16
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作