题解 | #记录点赞用户#
记录点赞用户
http://www.nowcoder.com/practice/19a766a67cdc4eb0a354d70597cf008b
-
由于本题为记录点赞的用户列表,所以应该选择某个集合来存储用户。首先分析业务需求来选定使用什么集合,在这个业务需求下,顺序并不重要,但姓名应不重复,所以最好选择遍历速度和插入删除速度快的Set集合来存储点赞用户,集合内存放的数据类型为String,代码参考写法为: private HashSet names = new HashSet();
-
根据预设代码得知,需要补全代码的部分为LikeRecorder接口的实现类,那么这里应该重写接口中的方法。like方法中传入用户名作为参数,用if语句判断集合中是否包含此用户名,包含则将此用户名移除,不包含则向集合中添加此用户名。判断集合中是否存在该对象,可以使用contains方法。
这部分的代码参考写法为:
@Override
public void like(String name) {
if (names.contains(name)) {
names.remove(name);
} else {
names.add(name);
}
}
预设代码中,输出格式为Arrays.toString,因此我们应该将getLikeUsers方法的返回值设置为数组类型,那么getLikeUsers()方法应将HashSet集合转化为数组,那么这里就可以调用 HashSet集合的toArray方法
代码参考写法如下:
@Override
public String[] getLikeUsers() {
return names.toArray(new String[0]);
}
附上完整代码:
import java.util.*;
public class Main {
public static void main(String[] args) {
LikeRecorder recorder = new LikeRecorderImpl();
Scanner scanner = new Scanner(System.in);
while (scanner.hasNext()) {
String name = scanner.next();
recorder.like(name);
}
System.out.println(Arrays.toString(recorder.getLikeUsers()));
}
}
/**
* 点赞记录器
*/
interface LikeRecorder {
/**
* 若用户没有点赞过,则记录此次点赞行为。
* 若用户曾经点赞过,则删除用户点赞记录。
*
* @param username 用户名
*/
void like(String username);
/**
* 返回所有点赞的用户名
*
* @return 用户名数组
*/
String[] getLikeUsers();
}
class LikeRecorderImpl implements LikeRecorder {
private HashSet<String> names = new HashSet();
@Override
public void like(String name) {
if (names.contains(name)) {
names.remove(name);
} else {
names.add(name);
}
}
@Override
public String[] getLikeUsers() {
return names.toArray(new String[0]);
}
// write your code here......
}