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

相关推荐

关于“实习生工资多少才算正常”,其实并没有一个放之四海而皆准的标准,但如果结合一线城市的生活成本、工作强度以及实习本身创造的价值来看,我个人认为6000&nbsp;元左右应当是一个基本及格线,也就是每天&nbsp;200&nbsp;多元。如果能达到&nbsp;300、400&nbsp;元一天,甚至更高,那无疑是更理想的状态。首先,从现实成本看,房租、通勤、餐饮几乎都是刚性支出。低于这个水平的实习,往往意味着实习生需要用家庭或存款“倒贴”工作,这在长期来看并不合理。实习本质上是学习,但并不等于“廉价劳动力”,更不应该是经济压力的来源。其次,愿意给实习生更高薪资的公司,通常不会是差公司。这至少说明两点:一是公司资金相对充足,不是靠压缩人力成本勉强维持;二是公司认可实习生的价值,希望你真正参与业务、创造产出,而不是只做边角料工作。很多高薪实习往往伴随着更规范的培养体系、更高的信息密度和更真实的项目经验。当然,高工资并不等于一切,但它往往是一个重要信号。能给到&nbsp;300、400&nbsp;元一天甚至更多的公司,往往对效率、能力和长期发展更有追求,也更可能处在一个有前景的赛道中。总结来说,实习工资不仅是钱的问题,更是公司态度、实力和发展前景的体现。在条件允许的情况下,争取一份“付得起你时间”的实习,本身就是一种理性选择。
北国牛马:你是不是忘了你一周只能上五天班,月薪6000那你日薪就得300了,日薪200一个月也就4000,也就刚好覆盖生活成本了
实习生工资多少才算正常?
点赞 评论 收藏
分享
评论
7
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务