day24(12.4)——leetcode面试经典150

202. 快乐数

202. 快乐数

这总感觉就是找规律的题!

题目:

题解:

java 复制代码
class Solution {
    public boolean isHappy(int n) {
        //这里要多用几个数去试,就能发现规律了
        //规律就是如果不能循环得到1的数一定会进行循环,进入死循环
        //只需要将每次都得到的数放入map中进行纪律,一旦得到的数出现过就return false
        //如果得到1就直接返回true
        int x=n;
        Map<Integer,Integer> map = new HashMap<>();
        while(true) {
            map.put(x,1);
            if(x==1) {
                return true;
            }
            int sum=0;
            while(x>0) {
                int g = x%10;
                sum+=g*g;
                x/=10;
            }
            x=sum;
            if(map.containsKey(x)) {
                break;
            }
        }
        return false;
    }
}

219. 存在重复元素 II

219. 存在重复元素Ⅱ

不是这题跟1. 两数之和做法几乎一模一样,秒了,很快就写完了,到了这一章才发现map这么好用!!!

题目:

题解:

java 复制代码
class Solution {
    public boolean containsNearbyDuplicate(int[] nums, int k) {
        Map<Integer,Integer> map=new HashMap<>();
        for(int i=0;i<nums.length;i++) {
            if(map.containsKey(nums[i])&&Math.abs(map.get(nums[i])-i)<=k) {
                return true;
            }
            map.put(nums[i],i);
        }
        return false;
    }
}
相关推荐
程序员小远2 小时前
软件测试用例总结
自动化测试·软件测试·python·功能测试·测试工具·职场和发展·测试用例
im_AMBER2 小时前
手撕发布订阅与观察者模式:从原理到实践
前端·javascript·面试
打瞌睡的朱尤3 小时前
4.9蓝桥杯
职场和发展·蓝桥杯
yuki_uix3 小时前
遇到前端题目,我现在会先问自己这四个问题
前端·面试
Wect3 小时前
JS 手撕:对象创建、继承全解析
前端·javascript·面试
一江寒逸3 小时前
零基础从入门到精通MySQL(附加篇):面试八股文全集
数据库·mysql·面试
zjeweler4 小时前
网安护网面试-2-国誉护网面试
web安全·网络安全·面试·职场和发展·护网行动·护网面试
人道领域4 小时前
【LeetCode刷题日记】383 赎金信
算法·leetcode·职场和发展
不会写DN4 小时前
Vue3中的computed 与 watch 的区别
javascript·面试·vue
不会写DN5 小时前
IPv4 与 IPv6 的核心区别
计算机网络·面试·golang