9.25-编程刷题

1.两数之和

java 复制代码
class Solution {
    public int[] twoSum(int[] nums, int target) {
        int n=nums.length;
        Map<Integer,Integer> map=new HashMap<>();
        for(int i=0;i<n;i++){
            if(map.containsKey(target-nums[i])){
                return new int[]{map.get(target-nums[i]),i};
            }else{
                map.put(nums[i],i);
            }
        }
        return new int[0];
    }
}

2.快乐数

java 复制代码
class Solution {
    public int getNext(int n){
        int totalSum=0;
        while (n>0){
            int temp=n%10;
            n=n/10;
            totalSum+=temp*temp;
        }
        return totalSum;
    }
    public boolean isHappy(int n) {
        Set<Integer> set=new HashSet<>();
        while (n!=1 && !set.contains(n)){
            set.add(n);
            n=getNext(n);
        }
        return n==1;
    }
}

3.存在重复元素 II

java 复制代码
class Solution {
    public boolean containsNearbyDuplicate(int[] nums, int k) {
        Map<Integer,ArrayList<Integer>> map=new HashMap<>();
        int n=nums.length;
        for(int i=0;i<n;i++){
            if(!map.containsKey(nums[i])){
                ArrayList<Integer> list=new ArrayList<>();
                list.add(i);
                map.put(nums[i],list);
            }else{
                ArrayList<Integer> integers = map.get(nums[i]);
                integers.add(i);
                map.put(nums[i],integers);
            }
        }
        for(Map.Entry<Integer,ArrayList<Integer>> entry: map.entrySet()){
            if(entry.getValue().size()>1){
                for(int i=0;i<entry.getValue().size()-1;i++){
                    if(entry.getValue().get(i+1)-entry.getValue().get(i)<=k){
                        return true;
                    }
                }
            }
        }
        return false;
    }
}
java 复制代码
class Solution {
    public boolean containsNearbyDuplicate(int[] nums, int k) {
        Map<Integer, Integer> map = new HashMap<Integer, Integer>();
        int length = nums.length;
        for (int i = 0; i < length; i++) {
            int num = nums[i];
            if (map.containsKey(num) && i - map.get(num) <= k) {
                return true;
            }
            map.put(num, i);
        }
        return false;
    }
}
相关推荐
进击的荆棘31 分钟前
优选算法——双指针
数据结构·算法
努力努力再努力wz32 分钟前
【Linux网络系列】:JSON+HTTP,用C++手搓一个web计算器服务器!
java·linux·运维·服务器·c语言·数据结构·c++
魂梦翩跹如雨33 分钟前
死磕排序算法:手撕快速排序的四种姿势(Hoare、挖坑、前后指针 + 非递归)
java·数据结构·算法
夏鹏今天学习了吗8 小时前
【LeetCode热题100(87/100)】最小路径和
算法·leetcode·职场和发展
哈哈不让取名字8 小时前
基于C++的爬虫框架
开发语言·c++·算法
Lips61110 小时前
2026.1.20力扣刷题笔记
笔记·算法·leetcode
2501_9413297210 小时前
YOLOv8-LADH马匹检测识别算法详解与实现
算法·yolo·目标跟踪
洛生&10 小时前
Planets Queries II(倍增,基环内向森林)
算法
小郭团队11 小时前
1_6_五段式SVPWM (传统算法反正切+DPWM2)算法理论与 MATLAB 实现详解
嵌入式硬件·算法·matlab·dsp开发
小郭团队11 小时前
1_7_五段式SVPWM (传统算法反正切+DPWM3)算法理论与 MATLAB 实现详解
开发语言·嵌入式硬件·算法·matlab·dsp开发