day23(12.3)——leetcode面试经典150

49. 字母异位词分组

49. 字母异位词分组

我傻逼了,我以为要排序呢,搁那库库捣鼓List<List<String>>怎么排序,结果竟然不用我排

题目:

题解:

java 复制代码
class Solution {
    public List<List<String>> groupAnagrams(String[] strs) {
        List<List<String>> list = new ArrayList<>();
        Map<String,List<String>> map = new HashMap<>();
        for(int i=0;i<strs.length;i++) {
            String s = strs[i];
            char[] chars = s.toCharArray();
            Arrays.sort(chars);
            s = new String(chars);
            //如果ls中存在该值,则说明有对应的异构词
            if(map.containsKey(s)) {
                List<String> ss = map.get(s);
                ss.add(strs[i]);
                map.replace(s,ss);
            }
            //ls中不存在该值,则说明不存在,进行创建
            else {
                List<String> ss = new ArrayList<>();
                ss.add(strs[i]);
                map.put(s, ss);
            }
        }
        for (Map.Entry<String, List<String>> entry : map.entrySet()) {
            List<String> value = entry.getValue();
            //这里是List集合,不能用Arrays.sort()来排序
            // Arrays.sort(value);
            // Collections.sort(value);
            list.add(value);
        } 
        // Collections.sort(list);不能这么直接进行排序
        // list.sort(Comparator.comparingInt((List<String> x) -> x.size())
        //       .thenComparing((List<String> a, List<String> b) -> {
        //           for (int i = 0; i < Math.min(a.size(), b.size()); i++)                 {
        //               int cmp = a.get(i).compareTo(b.get(i));
        //               if (cmp != 0) return cmp;
        //             }
        //           return 0;
        //       }));
        return list;
    }
}

1. 两数之和

1. 两数之和

题目:

题解:

java 复制代码
class Solution {
    public int[] twoSum(int[] nums, int target) {
        //转成list能直接找到下标
        List<Integer> list = Arrays.stream(nums)
    .boxed()
    .collect(Collectors.toList());
        Map<Integer,Integer> map = new HashMap<>();
        for(int i=0;i<nums.length;i++) {
            map.put(nums[i], map.getOrDefault(nums[i], 0)+1);
        }
        for(int i=0;i<nums.length;i++) {
            if(map.containsKey(target-nums[i])&&map.get(target-nums[i])>=1) {
                //如果两个数相等
                if(nums[i]==target-nums[i]&&map.get(target-nums[i])>=2) {
                    //直接返回两个数的下标
                    return new int[]{i,list.lastIndexOf(nums[i])};
                }
                else if(nums[i]!=target-nums[i]){
                    return new int[]{i,list.indexOf(target-nums[i])};
                }
            }
        }
        return new int[2];
    }
}

看了题解,发现这么简单!!!

java 复制代码
class Solution {
    public int[] twoSum(int[] nums, int target) {
        Map<Integer,Integer> map = new HashMap<>();
        for(int i=0;i<nums.length;i++) {
            if(map.containsKey(target-nums[i])) {
                return new int[]{i,map.get(target-nums[i])};
            }
            map.put(nums[i],i);
        }
        //因为一定存在,所以直接返回一个空的长度为2的数组就行了
        return new int[2];
    }
}
相关推荐
vx1_Biye_Design2 分钟前
基于Spring Boot+Vue的学生管理系统设计与实现-计算机毕业设计源码46223
java·vue.js·spring boot·spring·eclipse·tomcat·maven
vx_Biye_Design3 分钟前
基于Spring Boot+vue的湖北旅游景点门票预约平台的设计--毕设附源码29593
java·vue.js·spring boot·spring cloud·servlet·eclipse·课程设计
hay_lee22 分钟前
Spring AI实现对话聊天-流式输出
java·人工智能·ollama·spring ai
Hx_Ma1628 分钟前
SpringBoot数据源自动管理
java·spring boot·spring
SunnyDays101129 分钟前
Java 高效实现 CSV 转 Excel
java·csv转excel
starfire_hit30 分钟前
JAVAWEB根据前台请求获取用户IP
java·服务器·网络
fengxin_rou31 分钟前
[Redis从零到精通|第四篇]:缓存穿透、雪崩、击穿
java·redis·缓存·mybatis·idea·多线程
像少年啦飞驰点、34 分钟前
从零开始学 RabbitMQ:小白也能懂的消息队列实战指南
java·spring boot·微服务·消息队列·rabbitmq·异步编程
宠友信息42 分钟前
2025社交+IM及时通讯社区APP仿小红书小程序
java·spring boot·小程序·uni-app·web app
java1234_小锋43 分钟前
Java高频面试题:Spring和SpringBoot的关系和区别?
java·spring boot·spring