鱼C论坛

 找回密码
 立即注册
查看: 2349|回复: 0

[学习笔记] leetcode 387. First Unique Character in a String

[复制链接]
发表于 2019-9-14 14:04:41 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. Given a string, find the first non-repeating character in it and return it's index. If it doesn't exist, return -1.

  2. Examples:

  3. s = "leetcode"
  4. return 0.

  5. s = "loveleetcode",
  6. return 2.
  7. Note: You may assume the string contain only lowercase letters.
复制代码

  1. class Solution {
  2.    
  3.     int count = 0;
  4.     public int firstUniqChar(String s) {
  5.         
  6.         if(s.length() == 1) return 0;
  7.         if(s.length() == 0 || count == s.length()) return -1;
  8.         if(count > s.length()) return -1;
  9.         
  10.         if(count <= s.length() -1 && (s.substring(count+1,s.length()).indexOf(s.substring(count,count+1)) != -1 || s.substring(0,count).indexOf(s.substring(count,count+1)) != -1)){
  11.             count++;
  12.             return firstUniqChar(s);   
  13.         }
  14.         else return count;
  15.         
  16.         
  17.     }
  18. }
复制代码

  1. class Solution {
  2.    
  3.     public int firstUniqChar(String s) {
  4.         if(s.length() == 0) return -1;

  5.         String [] arr = s.split("");
  6.         
  7.         int max = Integer.MIN_VALUE;
  8.         for(int i = 0; i < arr.length ; i++){
  9.             
  10.             if (Integer.valueOf(arr[i].charAt(0)) > max) max = Integer.valueOf(arr[i].charAt(0));
  11.         }
  12.         int[] re = new int[max+1];
  13.                                                                               
  14.         for(int i = 0; i< arr.length ; i++){
  15.             
  16.             re[Integer.valueOf(arr[i].charAt(0))]++;
  17.         }
  18.                                                                               
  19.         for(int i = 0; i< arr.length ; i++){
  20.             
  21.             if(re[Integer.valueOf(arr[i].charAt(0))] == 1) return i;
  22.         }                                                                     
  23.         return -1;
  24.     }
  25. }
复制代码

  1. class Solution {
  2.    
  3.     public int firstUniqChar(String s) {
  4.         
  5.         if(s.length() == 0) return -1;
  6.         
  7.         int[] arr = new int[26];
  8.         
  9.         for(int i = 0; i< s.length() ; i++){
  10.             
  11.             arr[s.charAt(i) - 'a']++;
  12.         }
  13.         
  14.         for(int i = 0; i< s.length() ; i++){
  15.             
  16.             if(arr[s.charAt(i) - 'a'] == 1) return i;
  17.         }
  18.         return -1;
  19.     }
  20. }
复制代码

  1. class Solution {
  2.    
  3.     public int firstUniqChar(String s) {
  4.         
  5.         if(s.length() == 0) return -1;
  6.         
  7.         char[] arr = s.toCharArray();
  8.         
  9.         int[] re = new int[256];
  10.         
  11.         for(char i :arr) re[i]++;
  12.         
  13.         for(int i = 0; i< arr.length; i++){
  14.             
  15.             if(re[arr[i]] == 1) return i;
  16.         }
  17.         return -1;
  18.     }
  19. }
复制代码

本帖被以下淘专辑推荐:

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-5-13 16:16

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表