24小时热门版块排行榜    

CyRhmU.jpeg
查看: 2229  |  回复: 9
本帖产生 1 个 程序强帖 ,点击这里进行查看
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

holmescn

金虫 (正式写手)

[交流] Euler 工程 第廿六题:最长的循环节已有4人参与

鉴于刚才发的那了Fibonacci数列的题太无聊,可能用C写大数加法也不会太慢,所以再发一个吧,这个有点意思了。

分子为1的分数可以写成一个有限小数或者无限循环小数。比如分母从2到10的分数就写为:

1/2        =         0.5
1/3        =         0.(3)
1/4        =         0.25
1/5        =         0.2
1/6        =         0.1(6)
1/7        =         0.(142857)
1/8        =         0.125
1/9        =         0.(1)
1/10 =         0.1

这里, 0.1(6) 表示0.1666666......。可见其循环节为1个数字。而1/7则有6个数字的循环节。

那么,分母小于1000的所有分子为1的分数中,谁的循环节最长呢?

[ Last edited by holmescn on 2011-6-11 at 10:09 ]
回复此楼

» 猜你喜欢

» 本主题相关商家推荐: (我也要在这里推广)

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

qinghuoly

木虫 (正式写手)

★ ★ ★
小木虫(金币+0.5):给个红包,谢谢回帖
xzhdty(金币+2): 欢迎到程序语言来 2011-06-27 10:03:40
循环小数1/d的循环节c长度为n;f为d因式分解后移除2和5的因子的乘积。则999...9(n个9)恰好能整除f。
n即为循环节长度。

例如
1/7=0.(142857)
1/12=0.08(3)    此时d为12,因式分解为 2 2 3;移除两个2,得到f=3 ; 999999/7=142857
1/420=0.00(238095)       此时d为420,因式分解为 2 2 3 5 7;移除两个2,一个5; 得到f=21 ; 999999/21=47619


循环节为142857


scheme语言解法:
CODE:
[define [ans26]

  [define N 1000]
  [define M [string->number [string-append "1" [make-string 30 #\0]]]]
  [define [recur n d]
    ;get the recurring cycle length of n/d
    [define [r counter x deno]
      [if [= 0 [remainder x deno]]
          counter
          [r [add1 counter]
             [+ 9 [* 10 x]]
             deno]]]
    [let* [[c [denominator
               [/ M
                  [denominator [/ n d]]]]]
           [o [add1 [order-of-magnitude c]]]
           ]
      [if [= c 1]
          0
          [r o
             [string->number
              [string-append
                     [make-string o #\9]]]
             c]]]]
  [define [c num max len]
    [if [= num N]
        [list max len]
        [if [>= len [recur 1 num]]
            [c [+ 1 num] max len]
            [c [+ 1 num] num [recur 1 num]]]]]
  [c 3 2 1]]

CODE:
> [time [ans26]]
cpu time: 531 real time: 547 gc time: 126
'(983 982)

耗时547 ms。答案为983,循环节长为982

[ Last edited by qinghuoly on 2011-6-27 at 22:52 ]
天地为帐,日月为灯,风雷为号角,云虹为旗令,山川为阵图,草木为兵卒。运阴阳五行为谋,策古今兴替为略。
10楼2011-06-27 07:20:36
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 holmescn 的主题更新
普通表情 高级回复(可上传附件)
信息提示
请填处理意见