zoukankan      html  css  js  c++  java
  • 快乐数

    快乐数(环 快慢指针)

    编写一个算法来判断一个数 n 是不是快乐数。
    
    「快乐数」定义为:对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和,然后重复这个过程直到这个数变为 1,也可能是 无限循环 但始终变不到 1。如果 可以变为  1,那么这个数就是快乐数。
    
    如果 n 是快乐数就返回 True ;不是,则返回 False 。
    
    示例:
    	输入:19
    	输出:true
    	解释:
    		12 + 92 = 82
    		82 + 22 = 68
    		62 + 82 = 100
    		12 + 02 + 02 = 1
    

    解题思路1:快慢指针

    ​ 慢指针每次做一次转换, 快指针每次做两次转换

    	public boolean isHappy(int n) {
            int slow=n,fast=squareSum(n);
            while(slow!=fast){
                slow=squareSum(slow);
                fast=squareSum(squareSum(fast));
            }
            return slow==1;
        }
        public int squareSum(int n){
            int sum=0;
            while(n>0){
                int digit=n%10;
                sum+=digit*digit;
                n/=10;
            }
            return sum;
        }
    

    解题思路2:HashMap

    ​ 用集合装载中间结果,如果出现重复元素,则出现环(无限循环)

    /**
         *   ArrayList        HashMap
         *   2ms   52%      1ms      99%
         *   36M    8%      36        8%
         * 用集合(List|Map)装载中间数据 ,如果重复出现某个元素(形成环)
         * @param n
         * @return
         */
        public boolean isHappy2(int n) {
    //        List<Integer> list = new ArrayList<>();
            Map<Integer,Integer> map=new HashMap<>();
            while(n!=1){
                int temp = 0;
                while (n > 0) {
                    temp += (n % 10) * (n % 10);
                    n/=10;
                }
                if(map.containsKey(temp)){
                    return false;
                }else{
                    n=temp;
                    map.put(temp,1);
                }
            }
            return true;
        }
    

    HashMap的containsKey(Value) ArrayList的contains()

    • list是逐个比较 O(n)
    • HashMap是先计算hashcode,然后定位到某个位置,再进行比较 复杂度为O(1),最坏情况(map不存在目标值)是O(n)
  • 相关阅读:
    Discuz!NT 系统架构分析
    jquery pager
    Nhibernate分页方法
    Discuz nt模板机制
    WTclient创建OPC client方法
    OPC
    Regular Expressions in Java
    How to use VS to manipulate Access
    OPC客户端设计
    How to use VS to manipulate Excel使用MFC读写Excel
  • 原文地址:https://www.cnblogs.com/yh-simon/p/12818862.html
Copyright © 2011-2022 走看看