• 由于本题为记录点赞的用户列表,所以应该选择某个集合来存储用户。首先分析业务需求来选定使用什么集合,在这个业务需求下,顺序并不重要,但姓名应不重复,所以最好选择遍历速度和插入删除速度快的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......

}