题目描述
给定一个字符串 s
,找到 它的第一个不重复的字符,并返回它的索引 。如果不存在,则返回 -1
。
示例 1:
输入: s = “leetcode”
输出: 0
示例 2:
输入: s = “loveleetcode”
输出: 2
示例 3:
输入: s = “aabb”
输出: -1
提示:
- 1 <= s.length <= 105
s
只包含小写字母
解题方法
- C 创建字母表
int firstUniqChar(char* s) { int alphabet[26] = {0}; // 定义字母表 int i = 0; // 更新字母表中每个字母出现的次数 for (i = 0; i < strlen(s); i++) { alphabet[s[i] - 'a']++; } // 查找第一个仅出现一次的字符 for (i = 0; i < strlen(s); i++) { if (alphabet[s[i] - 'a'] == 1) { return i; } } return -1; }
复杂度分析
时间复杂度为 O(n),n 为字符串的长度。
空间复杂度为 O(1)。