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;
    }
}
相关推荐
卡洛斯(编程版1 小时前
(1) 哈希表全思路-20天刷完Leetcode Hot 100计划
python·算法·leetcode
NAGNIP2 小时前
DeepSeekMoE 架构解析
算法
不喜欢学数学er2 小时前
算法第五十二天:图论part03(第十一章)
算法·深度优先·图论
养成系小王2 小时前
四大常用排序算法
数据结构·算法·排序算法
NAGNIP2 小时前
一文搞懂DeepSeek LLM
算法
已读不回1432 小时前
设计模式-策略模式
前端·算法·设计模式
MrZhangBaby2 小时前
SQL-leetcode—3374. 首字母大写 II
linux·sql·leetcode
CoovallyAIHub3 小时前
标注成本骤降,DINOv3炸裂发布!冻结 backbone 即拿即用,性能对标SOTA
深度学习·算法·计算机视觉
BB学长3 小时前
流固耦合|01流固耦合分类
人工智能·算法
汤永红3 小时前
week3-[分支嵌套]方阵
c++·算法·信睡奥赛