小红书推荐系统(小红书24秋招后端开发)
题面
核心思想
map记录String的出现次数
set去重+自定义排序
代码
import java.util.*;
import java.util.function.Function;
public class Main {
public static void main(String[] args) {
final long MOD = (long) (1e9 + 7);
Scanner scanner = new Scanner(System.in);
String s = scanner.nextLine();
String[] s1 = s.split(" ");
HashMap<String,Integer> v= new HashMap<>();
//统计次数
for(String ss: s1){
v.put(ss, v.getOrDefault(ss, 0) + 1);
}
TreeSet<String> st = new TreeSet<>(new Comparator<String>() {
@Override
public int compare(String o1, String o2) {
int cnt1 = v.get(o1);
int cnt2 = v.get(o2);
if(cnt1 != cnt2) {
return cnt2 - cnt1; // 按次数从大到小排序
}else {
return o1.compareTo(o2);// 字典升序
}
}
});
for(String ss: s1){
if(v.get(ss) >= 3) {
st.add(ss);
}
}
for(String ss: st)
System.out.println(ss);
}
}
本文作者:Shie1d
本文链接:https://www.cnblogs.com/ganyq/p/18119206
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY