第一个只出现一次的字符位置
题目:在一个字符串(1<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符的位置。若为空串,返回-1。位置索引从0开始。
思路:使用类似哈希表的结构,统计次数然后返回第一个出现次数为1的字符。时间和空间复杂度均为O(n)。
实现代码:
import java.util.*; public class Solution { public int FirstNotRepeatingChar(String str) { if(str == null || str.length() <= 0) return -1; int[] hashTable = new int[256]; char[] strChar = str.toCharArray(); Arrays.fill(hashTable, 0); for(char ch : strChar) { hashTable[(int)ch] ++; } for(int i=0; i<strChar.length; i++) { char ch = strChar[i]; if(hashTable[(int)ch] == 1) { return i; } } return -1; } }
作者:Pickle
声明:对于转载分享我是没有意见的,出于对博客园社区和作者的尊重一定要保留原文地址哈。
致读者:坚持写博客不容易,写高质量博客更难,我也在不断的学习和进步,希望和所有同路人一道用技术来改变生活。觉得有点用就点个赞哈。







