题目:在一个字符串中找到第一个没有重复元素的字符并返回。
例:输入:"yellow"
返回:“y”
输入:"tooth"
返回:“h”
输入:“coco”
返回:“”
按照人类思维来判断的话,比较该元素与后面的元素,如果相同,再比较下一个元素。如果都不相同,是在内循环之后判断的
伪代码:
for(。。。。){
for(........)
{
if(相同)
break;
}
if(标志牌没变)//说明都不相同
return。。。;
}
这个题目我在亚马逊电话面试中遇见过,后来再一家日本公司面试中也遇见过。尽管这个问题并没有涉及到比较高级的编程思想,比如动态编程dynamic Programming或者Divide and Conquer,但是如果对数据结构或者算法并不很熟练的人来说,还是会构成一定的困难。
好了,那么现在就来分析一下这个问题。
首先,最直观的解法就是利用循环挨个儿从第一个元素起往后面找有没有重复,如果遍历完成后还没有,那么这个元素就是第一个没有重复的元素,直接在循环体中返回值就可以了。那么具体解法就需要两个循环控制,第一个用来定位要查看的元素,第二个循环用来在字符串中找有没有跟他重复的元素。这个算法的时间复杂度是O(n2), 因为假设这个字符串中元素都有重复,那么第一个循环需要遍历n次,第二个循环也需要遍历n次。空间复杂度是O(c),为常数,因为我们并没有添加新的数据结构。Java代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
public
static
String findCharInPlace(String s){
int
len = s.length();
if
(len <=
0
)
return
null
;
boolean
repeated =
false
;
for
(
int
i=
0
;i<s.length();i++){
repeated =
false
;
int
j=
0
;
for
(;j<s.length();j++){
if
(j!=i&&s.charAt(j)==s.charAt(i)){
repeated =
true
;
break
;
}
}
if
(!repeated)
return
s.charAt(i)+
""
;
}
return
""
;
}
|