码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2018-02-17 15:50:54      阅读:174      评论:0      收藏:0      [点我收藏+]

标签:pen   lintcode   第一个   class   none   其他   函数   splay   for   

[抄题]:

给出一个字符串。找到字符串中第一个不重复的字符然后返回它的下标。如果不存在这样的字符,返回 -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;
    }
}
View Code

 

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

标签:pen   lintcode   第一个   class   none   其他   函数   splay   for   

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!