记录点赞用户


描述:

为了实现社区点赞功能,要求设计一个点赞记录器,该工具包含如下两个方法:

1. like方法:该方法需要传入用户名作为参数,如果用户没点赞过,则记录本次点赞行为,若用户已经点赞过,则删除他的点赞行为。

2. getLikeUsers方法:该方法需要返回所有点赞用户的名字,不要求顺序。

(为保证答案正确,请使用HashSet完成本题)


输入描述:

用户名 


输出描述: 

 所有点赞且未取消点赞的用户名,不要求顺序。(输出为Arrays.toString形式)


实例:


输入:

Tom Jim Lucy Lily Tom Lucy Tom

输出:

[Tom, Lily, Jim]

  • 由于本题为记录点赞的用户列表,所以应该选择某个集合来存储用户。首先分析业务需求来选定使用什么集合,在这个业务需求下,顺序并不重要,但姓名应不重复,所以最好选择遍历速度和插入删除速度快的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();
    public String[] getLikeUsers(){
        String[] str= new String[names.size()];
        return names.toArray(str);
    }
    public void like(String username){
        if(names.contains(username)){
            names.remove(username);
        }
        else{
            names.add(username);
        }
    }
    

}

猜你喜欢

转载自blog.csdn.net/m0_64799972/article/details/125622263