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

国内做网站公司排名百度地图排名可以优化吗

国内做网站公司排名,百度地图排名可以优化吗,获得网站管理员密码,wordpress 前台上传文件java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完):https://blog.csdn.net/grd_java/article/details/123063846 文章目录 数学:阶乘的10因子个数数学优化:思路转变为求5的倍数…
java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完):https://blog.csdn.net/grd_java/article/details/123063846

文章目录

    • 数学:阶乘的10因子个数
    • 数学优化:思路转变为求5的倍数的个数

在这里插入图片描述

数学:阶乘的10因子个数

解题思路:时间复杂度O( n n n),n为5的个数,空间复杂度O( 1 1 1)
  1. 如果想要求出阶乘,一定会超时。所以我们要找到破题点。就是什么条件下阶乘末尾会出现0。
  2. 我们发现阶乘结果求出来后,不断的提出因子10,能提出多少次,就有几个0. 例如5!=120. 此时进行因式分解为: 10 ∗ ( 12 ) . 10*(12). 10(12).一共提出1个10,因此一共一个0.
  3. 10是由2和5构成的。而且5的个数绝对更少。例如120 = 5 ∗ ( 24 ) 5*(24) 5(24) = 2 ∗ 2 ∗ 2 ∗ ( 15 ) 2*2*2*(15) 222(15).我们发现5的个数决定了阶乘结果中可以和2组成几个10.
  4. 因此我们可以先尝试统计n的阶乘中,5的个数。试一下效果

我们不需要每个阶乘数字都统计,例如5!中只有5这个数会出现5.因为5!=1*2*3*4*5.明眼人都知道,1,2,3,4不会有5的出现。

代码:最起码通过了对吗,说明想法没错,接下来法二会继续优化

在这里插入图片描述

class Solution {public int trailingZeroes(int n) {int ans = 0;//统计5的个数for (int i = 5; i <= n; i += 5) {//只有5,10,15,20,25....会出现5,其它数字不会出现5for (int x = i; x % 5 == 0; x /= 5) {//统计这些因子中的5的个数。例如100这个因子,可以拆解为5*5*4.有两个5++ans;//5的个数}}return ans;}
}

数学优化:思路转变为求5的倍数的个数

解题思路:时间复杂度O( l o g 2 n log_2n log2n),空间复杂度O( 1 1 1)
  1. 以1000为例:1000 = 5 ∗ 200 5*200 5200 = 5 ∗ 5 ∗ 40 5*5*40 5540 = 5 ∗ 5 ∗ 5 ∗ 8 5*5*5*8 5558 = 5 ∗ 5 ∗ 5 ∗ 5 ∗ 8 5 5*5*5*5*\dfrac{8}{5} 555558.则1000的阶乘的5的个数为200+40+8+1 = 249个
  2. 为什么对单个数字1000不断除5,可以求出1000的阶乘中5的个数呢?
  3. 因为我们需要转变思路,从现在开始,我们要统计从1到1000中,5的倍数出现的次数。
  1. 1到1000中,5的倍数出现200次, 200个5的倍数分别是 5 , 10 , 15 , 20 , . . . . . , 1000 5,10,15,20,.....,1000 5,10,15,20,.....,1000
    在这里插入图片描述
  2. 此时如果我们将这200个5的倍数,全部提出一个5,就会获得200个5. 并且因式分解后剩下的值看起来如下: 1 ∗ 2 ∗ 3 ∗ 4 ∗ 5 ∗ . . . . ∗ 200 1*2*3*4*5*....*200 12345....200,你会发现它们这些数正好组成了200的阶乘所有的数,
    在这里插入图片描述
  1. 此时,我们只需要从1到200这些数中,找当中5的倍数的个数。也就是 5 , 10 , 15 , 20 , . . . , 200 5,10,15,20,...,200 5,10,15,20,...,200
  1. 而200这个阶乘中,5的倍数共出现40次,我们将40次进行统计,然后继续对这40个5的倍数提出一个5的因子。你会发现它们又变成了40的阶乘。
    在这里插入图片描述
  1. 此时继续求40这个阶乘中,5的倍数出现的次数。结果如下:共8个5的倍数,我们将8个5提出后,剩下的数字组成了8的阶乘
    在这里插入图片描述
  2. 继续对8求:共1个5的倍数5,提出1个5后,剩下数字只有1了,也就不用继续遍历了
    在这里插入图片描述
  3. 最终,就可以将所有我们提出的5统计起来,200+40+8+1 = 249个。
代码

在这里插入图片描述

class Solution {public int trailingZeroes(int n) {int count = 0;//统计个数while (n != 0){//只要n的阶乘中还可以有5就继续n /= 5;//获取n这个阶乘中所有5的倍数的个数count += n;//统计个数}return count;}
}
http://www.yidumall.com/news/73302.html

相关文章:

  • 网站程序源码上传到空间打开网站首页还是显示的程序原源代码如何刷seo关键词排名
  • 如何提高网站的收录网站代搭建维护
  • 南宁网站seo长沙关键词优化推荐
  • 和规划网站如何武汉网站建设公司
  • wordpress添加自定义tag标签seo官网优化怎么做
  • 新乡做网站的公司泉州百度首页优化
  • 直播视频网站优化方案怎么写
  • 租木模板多少钱一平方如何做seo搜索优化
  • 使用vue做简单网站教程网站怎么制作教程
  • 淘客网站添加到桌面新网站多久会被百度收录
  • 韶关做网站的公司怎么找百度客服
  • 做网站什么什么就在刚刚武汉宣布最新消息
  • 用flash做网站市场营销策划方案
  • 坪洲网站建设网站怎么收录
  • wordpress 查看文章404南宁seo费用服务
  • 新乡营销网站建设bt磁力狗
  • 做美工需要参考的网站南京百度网站推广
  • 做劳保批发的网站免费二级域名注册申请
  • 如何用个人电脑做网站网络营销实施方案
  • 北京 做网站比较有名的足球比赛直播
  • 养老院网站建设方案长尾关键词什么意思
  • 到那里找做网站的兼职东莞网站建设最牛
  • 深圳科源建设集团有限公司网站旅游新闻热点
  • 途牛 招聘 网站开发网络营销的特征
  • 加强门户网站建设互动营销的案例及分析
  • 微网站开发报价互联网广告联盟
  • 网站建设普通发票税点西安seo诊断
  • wordpress文章自动分类旺道seo优化
  • 做网站 图片更好看百度在线
  • 商业网站建设方案整站seo服务