第一个独特字符位置 · first position unique character

[抄题]:

给出一个字符串。找到字符串中第一个不重复的字符然后返回它的下标。如果不存在这样的字符,返回 -1

给出字符串 s = "lintcode",返回 0
给出字符串 s = "lovelintcode",返回 2

[暴力解法]:

时间分析:

空间分析:

[思维问题]:

[一句话思路]:

用cnt[256]数组存储即可

[输入量]:空: 正常情况:特大:特小:程序里处理到的特殊情况:异常情况(不合法不合理的输入):

[画图]:

[一刷]:

不用break,因为有一个值可行时,int函数就直接返回了

[二刷]:

[三刷]:

[四刷]:

[五刷]:

[五分钟肉眼debug的结果]:

[总结]:

[复杂度]:Time complexity: O(n) Space complexity: O(n)

[英文数据结构或算法,为什么不用别的数据结构或算法]:

用数组存储字母,所谓的hash

[其他解法]:

[Follow Up]:

[LC给出的题目变变变]:

451. Sort Characters By Frequency 也是用256数组,再用heap排序

[代码风格] :

public class Solution {
    /**
     * @param s: a string
     * @return: it‘s index
     */
    public int firstUniqChar(String s) {
        //corner case
        if (s == null) {
            return 0;
        }
        //put into cnt[]
        char[] c = s.toCharArray();
        int[] cnt = new int[256];
        for (int i = 0; i < s.length(); i++) {
            cnt[c[i]]++;
        }
        //return
        for (int i = 0; i < s.length(); i++) {
            if (cnt[c[i]] == 1) {
                return i;
                //break;
            }
        }
        return -1;
    }
}

原文地址:https://www.cnblogs.com/immiao0319/p/8451929.html

时间: 2024-10-16 00:05:23

第一个独特字符位置 · first position unique character的相关文章

[LintCode] First Position Unique Character

Given a string, find the first non-repeating character in it and return it's index. If it doesn't exist, return -1. Example Given s = "lintcode", return 0. Given s = "lovelintcode", return 2. Solution 1. Two steps' iteration 1. first t

第一个只出现一次的字符位置-剑指Offer

第一个只出现一次的字符位置 题目描述 在一个字符串(1<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符的位置.若为空串,返回-1.位置索引从0开始 思路 每个字符都做对比的时间复杂度为O(n2),所以我们创建一个哈希表来存储每个字符对应的出现次数,扫描一次存储次数,扫描第二次找出第一个只出现一次的字符,时间复杂度O(n) 牺牲空间换取时间,哈希表查找的时间为O(1) 注意:最后没有符合这样条件的字符的情况 代码 public class Solution { publ

比较用户输入的两个文件,显示出所有不同处的行号与第一个不同字符的位置

1. 编写一个程序,比较用户输入的两个文件,如果不同,显示出所有不同处的行号与第一个不同字符的位置. import os import re cwd = os.getcwd() os.chdir(cwd) filename1 = input("请输入需要比较的头一个文件名:") filename2 = input("请输入需要比较的另一个文件名:") f1=open(filename1) f2=open(filename2) rownum = 0 count = 0

31.第一个只出现一次的字符位置

第一个只出现一次的字符位置 参与人数:2802时间限制:1秒空间限制:32768K 本题知识点: 字符串 算法知识视频讲解 题目描述 在一个字符串(1<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符的位置.若为空串,返回-1.位置索引从0开始 虽说C++的string类用起来超爽,但是和平时的使用习惯不同,我更喜欢原滋原味的C风格字符.这道题我写了两个版本,一个是C++风格的string,另一个是C风格字符串. 注意,C风格字符串中判断是否到达字符串末尾的两种方法:

C语言:对传入sp的字符进行统计,三组两个相连字母“ea”&quot;ou&quot;&quot;iu&quot;出现的次数,并将统计结果存入ct所指的数组中。-在数组中找出最小值,并与第一个元素交换位置。

//对传入sp的字符进行统计,三组两个相连字母“ea”"ou""iu"出现的次数,并将统计结果存入ct所指的数组中. 1 #include <stdio.h> 2 #include <string.h> 3 #pragma warning (disable:4996) 4 void fun(char*sp ,int *ct) 5 { 6 int a=0, b=0, c=0; 7 while (*sp != '\0') 8 { 9 if (*s

[LeetCode] 387. First Unique Character in a String 字符串的第一个唯一字符

Given a string, find the first non-repeating character in it and return it's index. If it doesn't exist, return -1. Examples: s = "leetcode" return 0. s = "loveleetcode", return 2. Note: You may assume the string contain only lowercase

shell 字符串中定位字符位置 获取字符位置

linux shell 字符串操作(长度,查找,替换)详解 该博文中描述的如下两个字符串操作, 1 ${string:position} #在$string中, 从位置$position开始提取子串 2 ${string:position:length} #在$string中, 从位置$position开始提取长度为$length的子串 需要用到字符/子串在父字符串中的位置(position);而shell字符串并未提供获取子串所在位置的接口,如果基于字符串变量的操作,则无法预知子串的位置: P

前端与算法 leetcode 387. 字符串中的第一个唯一字符

目录 # 前端与算法 leetcode 387. 字符串中的第一个唯一字符 题目描述 概要 提示 解析 解法一:双循环 解法二:Set法单循环 算法 传入测试用例的运行结果 执行结果 GitHub仓库 查看更多 # 前端与算法 leetcode 387. 字符串中的第一个唯一字符 题目描述 给定一个字符串,找到它的第一个不重复的字符,并返回它的索引.如果不存在,则返回 -1. 案例: s = "leetcode" 返回 0. s = "loveleetcode",

获取字符位置方法

charAt,获取相应位置字符(参数:字符位置) charCodeAt 获取相应位置字符unicode编码(参数:字符位置) var txt="abcdef" 比如,txt.charAt(4); 索引号一定是从0开始,所以返回的是d 我们根据我们输入的位数返回相应的字符. unicode编码是我们字符的字符唯一表示(检测字符串长度)