伍佰目录 短网址
  当前位置:海洋目录网 » 站长资讯 » 站长资讯 » 文章详细 订阅RssFeed

2021-05-16:时间复杂度必须是logN,如何求阶乘从右向左第一个不为零的数?

来源:本站原创 浏览:250次 时间:2021-05-27

2021-05-16:时间复杂度必须是logN,如何求阶乘从右向左第一个不为零的数?

福大大 答案2021-05-16:

这道题logN的解法是大步小步法,网上非常难找。另外论代码简洁度,明显是我的代码最简洁。你看了代码后,你会非常失望。因为你苦思冥想都想不出来的问题,原来这么简单。

假设数字是N。
1.当N能被5整除时,采用大步法。N变成N/5。
1.1.当N被4整除时。当N=20时,f(20)=f(4)。
1.2.当N被4整除余1时。当N=5时,f(5)=2f(1)。
1.3.当N被4整除余2时。当N=10时,f(10)=4
f(2)。
1.4.当N被4整除余3时。当N=15时,f(15)=8f(3)。
综合上述4种情况。f(N)=【2的(N&3)次方】
f(N/5)。
2.当N不能被5整除时,采用小步法。N变成N-1。当N=27时,f(27)=(27%10)f(26)=7f(26)。

代码用golang编写。代码如下:

package mainimport "fmt"func main() {    for i := 1;����,�˵� i <= 3125; i++ {        fmt.Println(i, FactRightNotZero(i))    }}func FactRightNotZero(n int) int {    ans := 1    for n > 0 {        if n%5 == 0 {            ans <<= n & 3 //这是精髓            n /= 5        } else {            ans *= n % 10            n--        }        ans %= 10    }    return ans}

执行结果如下:

  推荐站点

  • At-lib分类目录At-lib分类目录

    At-lib网站分类目录汇集全国所有高质量网站,是中国权威的中文网站分类目录,给站长提供免费网址目录提交收录和推荐最新最全的优秀网站大全是名站导航之家

    www.at-lib.cn
  • 中国链接目录中国链接目录

    中国链接目录简称链接目录,是收录优秀网站和淘宝网店的网站分类目录,为您提供优质的网址导航服务,也是网店进行收录推广,站长免费推广网站、加快百度收录、增加友情链接和网站外链的平台。

    www.cnlink.org
  • 35目录网35目录网

    35目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向35目录推荐、提交优秀网站。

    www.35mulu.com
  • 就要爱网站目录就要爱网站目录

    就要爱网站目录,按主题和类别列出网站。所有提交的网站都经过人工审查,确保质量和无垃圾邮件的结果。

    www.912219.com
  • 伍佰目录伍佰目录

    伍佰网站目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向伍佰目录推荐、提交优秀网站。

    www.wbwb.net