【Java - J - 50】第一个只出现一次的字符_字符串中

本文介绍了如何在Java中找到字符串中第一个只出现一次的字符。提供了两种方法,包括O(n^2)时间复杂度的逐个比较和O(n)时间复杂度的哈希解决方案。哈希方法在扫描字符串时更新字符出现次数,空间复杂度为O(1)。
摘要由CSDN通过智能技术生成
题目描述

题目一:字符串中第一个只出现一次的字符。
在字符串中找出第一个只出现一次的字符。如,输入"abaccdeff",则输出’b’。

练习地址

实现

方法:
1)扫描一个,和后面的每个字符比较,时间复杂度O( n 2 n^2 n2)
2)哈希:扫描一遍,更新出现次数,时间复杂度O(n),空间复杂度O(1)。
更新一个字符出现的次数O(1)
查询一个字符出现的次数O(1)

// 实现一个简单的哈希表的功能,时间复杂度O(n)
public class C50_string_FirstNotRepeatingChar {
    static char firstNotRepeatingChar(String str) {
        if (str == null || str.length()==0) {
            return ' ';
        }
        // 字符(char)是一个长度为8的数据类型,因此共有256种可能
        // 创建大小为256,以字符ASCII码为键值的哈希表
        int[] hash = new int[256];
        // 统计出现次数,存在数组中
        for (int i = 0; i < str.length(); i++) {
            int temp = str.charAt(i);
            hash[temp]++;
        }
        // 顺序遍历,将出现的次数为1的字符打印出来
        for (int i = 0; i < str.length(); i++) {
            char temp = str.charAt(i);
            if (hash[temp] == 1) {
                return temp;
            }
        }
        return ' ';
    }
}
Test
    public static void main(String[] args) {
        String str = "abaccdeff";
        System.out.println(firstNotRepeatingChar(str));
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值