当前位置: 首页 > wzjs >正文

包头网站seo优化运营专员

包头网站,seo优化运营专员,做酒店网站多少钱,物流公司网页设计题号202 编写一个算法来判断一个数 n 是不是快乐数。 「快乐数」 定义为: 对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和。然后重复这个过程直到这个数变为 1,也可能是 无限循环 但始终变不到 1。如果这个过程 结果为 1&a…

题号202

编写一个算法来判断一个数 n 是不是快乐数。

「快乐数」 定义为:

  • 对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和。
  • 然后重复这个过程直到这个数变为 1,也可能是 无限循环 但始终变不到 1。
  • 如果这个过程 结果为 1,那么这个数就是快乐数。

如果 n 是 快乐数 就返回 true ;不是,则返回 false 。

我的失败写法

/*class Solution {public boolean isHappy(int n) {String numstr=String.valueOf(n);//用自带函数将其转换为字符串int ans=0;while(ans!=1){ans=0;for(int i=0;i<numstr.length();i++){ans+=(numstr.charAt(i)-'0')*(numstr.charAt(i)-'0');}numstr=String.valueOf(ans);if(ans==1)return true;}return false;//缺点是遇到循环无法跳出}
}*/

改进后

class Solution {public boolean isHappy(int n) {String numstr=String.valueOf(n);int ans=0;Set<Integer> set=new HashSet<Integer>();//用哈希集合来记录while(ans!=1){ans=0;for(int i=0;i<numstr.length();i++){ans+=(numstr.charAt(i)-'0')*(numstr.charAt(i)-'0');}numstr=String.valueOf(ans);if(!set.contains(ans))//如果集合中不存在该数,则添加set.add(ans);else//若存在,说明已经有循环,则为无限循环,返回falsereturn false;         }return true;}
}

改进的关键在于,知道如何判断出现了无限循环:即产生了已经出现过的数字

再改进版

class Solution {public boolean isHappy(int n) {     Set<Integer> set=new HashSet<Integer>();while(getResult(n)!=1){if(set.contains(getResult(n)))return false;else{set.add(getResult(n));n=getResult(n);}}return true;}public int getResult(int n){int sum=0;while(n!=0){int a=n%10;//对10取模 得出个位的数字n/=10;//n除以10 自动更新为去除掉个位sum+=a*a;}return sum;}
}

此时改进了对于求每个数字平方和的算法:不必每一位均记录下来,数位分离的方法,可采用先对10求模再除以10更新自身的方法。

快慢指针法

class Solution {public boolean isHappy(int n) {int slow=n;int fast=getNext(n);while(fast!=1){slow=getNext(slow);fast=getNext(getNext(fast));if(slow==fast)return false;}return true;}public int getNext(int n){int sum=0;while(n!=0){int a=n%10;//对10取模 得出个位的数字n/=10;//n除以10 自动更新为去除掉个位sum+=a*a;}return sum;}
}

即在上一个解法中搞清楚这题关键是要判断有没有循环后,我们的任务就成了熟悉的判断是否有循环,DAY 31 leetcode 142--链表.环形链表-CSDN博客在这一篇中我们已经学习过在链表里面处理循环问题,而判断是否有环更简单,只需要fast指针和slow指针相遇即可(fast一次走两步,slow一次走一步)而此题中,通过反复调用 getNext(n) 得到的链是一个隐式的链表。可以使用这种方法。

http://www.dtcms.com/wzjs/497775.html

相关文章:

  • 可以做推广东西的网站网站seo需要用到哪些工具
  • 医院建设网站与托管惠州抖音seo策划
  • 建站公司 商城哪里可以接广告
  • 免费在线观看韩国电视剧网站推荐石家庄关键词优化平台
  • oto网站开发江西省水文监测中心
  • 购物网站素材网络运营培训班
  • 商城手机网站建设数据分析培训
  • 广东网站建设找哪家怎么做好网站搜索引擎优化
  • 网站建设项目的预表营销策划公司排行榜
  • wordpress 4 按钮 不显示沈阳关键词seo
  • wordpress 网站开发申请百度账号注册
  • 建设装修公司网站什么是网站推广?
  • 三明建设局网站it学校培训学校哪个好
  • 网站制作的公司哪个好如何制作网页教程
  • 网站建设面谈销售话术软件推广平台有哪些
  • 空间建网站seo关键词排名优化怎么收费
  • 宁波手机网站制作重庆森林在线观看
  • 非遗网站建设目的内蒙古seo优化
  • 网站建设有增值税发票吗武汉seo网站优化技巧
  • 洛阳鼎和电力建设有限公司网站sem网络营销
  • 广州市手机网站建设最近的新闻事件
  • 为什么企业需要建设网站宁波seo关键词优化制作
  • 网站建设完整代码app推广之家
  • 工业电商网站怎么配色关键词搜索爱站
  • 中国建设监理协会网站继续教育百度小说搜索风云榜
  • 外贸平台网站有哪些下载百度网盘
  • wordpress怎么连接空间seo建站需求
  • 湛江专业网站建设怎么做广州番禺发布
  • 网站设计公司-信科网络百度网盘app下载
  • 门户网站 模板之家徐州百度seo排名优化