题目描述
找出字符串中第一个只出现一次的字符
输出第一个只出现一次的字符,如果不存在输出-1
eg:
输入:
asdfasdfo
aabb
输出:
o
-1
以下是本篇文章正文内容,下面案例可供参考
解题思路
由题意知,要找出只出现一次的第一个字符,可以判断这个字符的第一位和最后一位的索引是否相等,若相等说明只出现了一次
代码如下
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
while(sc.hasNext()) {
String str = sc.nextLine();
char[] ch = str.toCharArray();
String ret = "-1";//若,不存在,直接返回的为-1
for(int i = 0;i < ch.length; i++) {
if(str.indexOf(ch[i])==str.lastIndexOf(ch[i])) {
ret = ch[i]+"";
break;//跳出循环,此时已经找到第一个只出现一次的字符
}
}
System.out.println(ret);
}
}
}
注意
注意找到这个字符时,必须break
,这即是找到的第一个只出现一次的字符