java实现输出字符串中第一个出现不重复的字符详解
2017-04-24 09:04
756 查看
java实现输出字符串中第一个出现不重复的字符详解
比如:输入name输出n,输入teeter输出r,输入namename输出null
具体实现代码如下:
import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner in = new Scanner(System.in); String str = in.next(); for(int i =0 ; i < str.length() ; i++) { if(str.lastIndexOf(str.char(i)) == i && str.indexOf(str.char(i)) == i) { System.out.println(str.char(i)); break; } } } }
在这个实现代码中我们使用了String类的三个方法成员:
String.length():获取字符串的长度
String.charAt(int index):获取索引index的字符
String.lastIndexOf(char c):获取字符c最后一次出现在字符串中的索引
String.indexOf(char c):获取字符c第一次出现在字符串中的索引
其实我们也可以不使用字符串的这些方法就可以实现了,下面是我个人使用for循环来实现的代码:
import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner in = new Scanner(System.in); String str = in.next(); char[] cb = new char[str.length()]; //将字符串中的字符一次存入cb[] for(int i =0 ;i <str.length() ; i++) { cb[i] = str.charAt(i); } for(int i = 0 ; i < str.length() ; i++) { for(int j = 0 ; j < str.length() ; j++) { if(cb[i] == cb[j] && cb[i] != '0') { char c = cb[i]; for(int z = 0 ; z < str.length() ; z++) { if(cb[z] == c) cb[z] = '0'; } } } } for(int i = 0 ; i <str.length() ; i++) { if(cb[i] != '0') { System.out.println(cb[i]); break; } } } }
这种方法可以实现,不过这种方法的时间复杂度特别的大,系统开销也特别大,因此我们最好不要使用循环嵌套,除非迫不得已,不然对系统开销是很大的。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
您可能感兴趣的文章:
相关文章推荐
- 用java实现输出字符串中第一个出现不重复的字符
- 给定一字符串,求字符串中第一次出现的非重复的字符,例如abaaedgff,输出b.(Java 实现)
- 用java实现,查找字符串中第一个没有重复出现的字符
- java实现--字符串中第一个单独出现的字符
- 算法--06谷歌面试:字符串中第一个只出现一次的字符(Java实现)
- 在一个字符串中找到第一个只出现一次的字符(JAVA实现)
- Java:在一个字符串中找到第一个只出现一次的字符。如输入abaccdeff,则输出b。
- 华为OJ ---找出字符串中第一个只出现一次的字符(java实现)
- 16、JAVA 找出一个字符串中,第一个重复出现的字符
- JAVA实现 剑指offer—求字符串中第一个只出现一次的字符
- Java实现:在字符串中找到第一个不重复的字符
- 在一个字符串中找到第一个只出现一次的字符(java实现)
- C++实现一个栈,出栈,入栈,返回最小值 时间复杂度为O(1),查找字符串中第一个重复出现的字符
- 在一个字符串中找到第一个只出现一次的字符(java实现)
- java实现如何在字符串中找到第一个不重复的字符
- 【Java笔试题】输出字符串中第一个不重复的字符
- 在一个字符串中找到第一个只出现一次的字符(java实现)
- No17、题目:在一个字符串中找到第一个只出现一次的字符。如输入 abaccdeff,则输出 b。
- 在一个字符串中找到第一个只出现一次的字符。如输入abaccdeff,则输出b
- 在一个字符串中找到第一个只出现一次的字符。如输入abaccdeff,则输出b;