Java 使用String类的Api进行查找

第一个只出现一次的字符

http://www.nowcoder.com/questionTerminal/1c82e8cf713b4bbeb2a5b31cf5b0417c

假设 输入的字符串为“google”

如果该字符只出现一次,那么从前开始查找和从后开始查找,找到的下标都应该是同一个。
但是如果最坏的情况下可能要多次遍历str

// 未优化版
public class Solution {
    public int FirstNotRepeatingChar(String str) {
        for (int i = 0; i < str.length(); i++) {
            if (str.indexOf(str.charAt(i)) == str.lastIndexOf(str.charAt(i)))
                return i;
        }
        return -1;
    }
}

而且我们可以发现,当字符出现一次时,它的位置为当前遍历的位置,所以可以把上述的判断条件改成,先看从前查找时返回的下标是否等于当前的位置,等于就从后开始查找,相同则返回。

// 优化版
// 使用HashSet保存出现不为一次的字符,并给HashSet设置初始容量,防止多次扩容带来额外的时间消耗
import java.util.HashSet;
public class Solution {
    public int FirstNotRepeatingChar(String str) {
        HashSet<Character> set = new HashSet<>(128);
        for (int i = 0; i < str.length(); i++) {
            char t = str.charAt(i);
            if (set.contains(t)) {
                continue;
            }
            if (str.indexOf(t) == i && str.lastIndexOf(t) == i){
                return i;
            }
            set.add(t);
        }
        return -1;
    }
}
// 优化版
// 不使用辅助空间存储出现次数不为1次的字符
public class Solution {
    public int FirstNotRepeatingChar(String str) {
        for (int i = 0; i < str.length(); i++) {
            char t = str.charAt(i);
            if (str.indexOf(t) == i && str.lastIndexOf(t) == i){
                return i;
            }
        }
        return -1;
    }
}
全部评论
lastIndexOf的时间复杂度很高吧。。
2 回复 分享
发布于 2020-01-13 10:22
API的时间复杂度没有考虑???
点赞 回复 分享
发布于 2020-06-15 21:54

相关推荐

蚂蚁 基架java (n+6)*16 签字费若干
点赞 评论 收藏
分享
ProMonkey2024:5个oc?厉害! 但是有一个小问题:谁问你了?😡我的意思是,谁在意?我告诉你,根本没人问你,在我们之中0人问了你,我把所有问你的人都请来 party 了,到场人数是0个人,誰问你了?WHO ASKED?谁问汝矣?誰があなたに聞きましたか?누가 물어봤어?我爬上了珠穆朗玛峰也没找到谁问你了,我刚刚潜入了世界上最大的射电望远镜也没开到那个问你的人的盒,在找到谁问你之前我连癌症的解药都发明了出来,我开了最大距离渲染也没找到谁问你了我活在这个被辐射蹂躏了多年的破碎世界的坟墓里目睹全球核战争把人类文明毁灭也没见到谁问你了(别的帖子偷来的,现学现卖😋)
点赞 评论 收藏
分享
评论
7
收藏
分享
牛客网
牛客企业服务