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 小时前
Leetcode热题100(跳跃游戏 II)
算法·leetcode·游戏
小白菜又菜7 小时前
Leetcode 3432. Count Partitions with Even Sum Difference
算法·leetcode
wuhen_n8 小时前
LeetCode -- 15. 三数之和(中等)
前端·javascript·算法·leetcode
sin_hielo8 小时前
leetcode 2483
数据结构·算法·leetcode
Xの哲學9 小时前
Linux多级时间轮:高精度定时器的艺术与科学
linux·服务器·网络·算法·边缘计算
大头流矢9 小时前
归并排序与计数排序详解
数据结构·算法·排序算法
油泼辣子多加9 小时前
【信创】算法开发适配
人工智能·深度学习·算法·机器学习
一路往蓝-Anbo9 小时前
【第20期】延时的艺术:HAL_Delay vs vTaskDelay
c语言·数据结构·stm32·单片机·嵌入式硬件
Aaron158810 小时前
AD9084和Versal RF系列具体应用案例对比分析
嵌入式硬件·算法·fpga开发·硬件架构·硬件工程·信号处理·基带工程
laocooon52385788610 小时前
插入法排序 python
开发语言·python·算法