Merge branch 'master' of git://factorcode.org/git/factor
[factor/jcg.git] / extra / project-euler / 057 / 057.factor
blob53240b0ec1dbea2176deb63bebdf3910447f466c
1 ! Copyright (c) 2008 Samuel Tardieu
2 ! See http://factorcode.org/license.txt for BSD license.
3 USING: kernel math math.functions math.parser sequences ;
4 IN: project-euler.057
6 ! http://projecteuler.net/index.php?section=problems&id=57
8 ! DESCRIPTION
9 ! -----------
11 ! It is possible to show that the square root of two can be expressed
12 ! as an infinite continued fraction.
14 ! √ 2 = 1 + 1/(2 + 1/(2 + 1/(2 + ... ))) = 1.414213...
16 ! By expanding this for the first four iterations, we get:
18 ! 1 + 1/2 = 3/2 = 1.5
19 ! 1 + 1/(2 + 1/2) = 7/5 = 1.4
20 ! 1 + 1/(2 + 1/(2 + 1/2)) = 17/12 = 1.41666...
21 ! 1 + 1/(2 + 1/(2 + 1/(2 + 1/2))) = 41/29 = 1.41379...
23 ! The next three expansions are 99/70, 239/169, and 577/408, but the
24 ! eighth expansion, 1393/985, is the first example where the number of
25 ! digits in the numerator exceeds the number of digits in the
26 ! denominator.
28 ! In the first one-thousand expansions, how many fractions contain a
29 ! numerator with more digits than denominator?
31 ! SOLUTION
32 ! --------
34 : longer-numerator? ( seq -- ? )
35     >fraction [ number>string length ] bi@ > ; inline
37 : euler057 ( -- answer )
38     0 1000 [ drop 2 + recip dup 1+ longer-numerator? ] count nip ;
40 ! [ euler057 ] time
41 ! 3.375118 seconds
43 MAIN: euler057