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

相关推荐

03-13 14:21
已编辑
江西警察学院 前端工程师
站队站对牛:红红一大片 天都要塌了
点赞 评论 收藏
分享
评论
7
收藏
分享

创作者周榜

更多
正在热议
更多
# 一张图晒出你司的标语 #
4472次浏览 78人参与
# 找AI工作可以去哪些公司? #
10192次浏览 322人参与
# 开放七大实习专项,百度暑期实习值得冲吗 #
15780次浏览 230人参与
# 你的实习产出是真实的还是包装的? #
20951次浏览 346人参与
# 从事AI岗需要掌握哪些技术栈? #
9889次浏览 397人参与
# 春招至今,你的战绩如何? #
68165次浏览 603人参与
# 厦门银行科技岗值不值得投 #
8264次浏览 188人参与
# AI面会问哪些问题? #
29225次浏览 638人参与
# 你做过最难的笔试是哪家公司 #
36179次浏览 319人参与
# 中国电信笔试 #
32411次浏览 302人参与
# 金三银四,你的春招进行到哪个阶段了? #
22601次浏览 284人参与
# 投递几十家公司,到现在0offer,大家都一样吗 #
341263次浏览 2176人参与
# 同bg的你秋招战况如何? #
212268次浏览 1121人参与
# 哪些公司真双非友好? #
69844次浏览 289人参与
# 如何准备秋招 #
78326次浏览 868人参与
# 阿里笔试 #
179514次浏览 1324人参与
# 应届生被毁约被毁意向了怎么办 #
63364次浏览 305人参与
# 机械人避雷的岗位/公司 #
62728次浏览 393人参与
# 小马智行求职进展汇总 #
25151次浏览 80人参与
# 第一份工作一定要去大厂吗 #
15303次浏览 129人参与
# 担心入职之后被发现很菜怎么办 #
291438次浏览 1210人参与
# 为了减少AI幻觉,你注入过哪些设定? #
26336次浏览 310人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务