<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://charlesreid1.com/w/index.php?action=history&amp;feed=atom&amp;title=Project_Euler%2F254</id>
	<title>Project Euler/254 - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://charlesreid1.com/w/index.php?action=history&amp;feed=atom&amp;title=Project_Euler%2F254"/>
	<link rel="alternate" type="text/html" href="https://charlesreid1.com/w/index.php?title=Project_Euler/254&amp;action=history"/>
	<updated>2026-06-20T05:07:10Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.39.12</generator>
	<entry>
		<id>https://charlesreid1.com/w/index.php?title=Project_Euler/254&amp;diff=22768&amp;oldid=prev</id>
		<title>Admin: Created page with &quot;We haven&#039;t cracked this one yet.  The naive implementation takes an astronomical amount of time, so this one, like many PE problems, requires some elegance and foresight.  Her...&quot;</title>
		<link rel="alternate" type="text/html" href="https://charlesreid1.com/w/index.php?title=Project_Euler/254&amp;diff=22768&amp;oldid=prev"/>
		<updated>2018-01-05T09:45:44Z</updated>

		<summary type="html">&lt;p&gt;Created page with &amp;quot;We haven&amp;#039;t cracked this one yet.  The naive implementation takes an astronomical amount of time, so this one, like many PE problems, requires some elegance and foresight.  Her...&amp;quot;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;We haven&amp;#039;t cracked this one yet.&lt;br /&gt;
&lt;br /&gt;
The naive implementation takes an astronomical amount of time, so this one, like many PE problems, requires some elegance and foresight.&lt;br /&gt;
&lt;br /&gt;
Here is a brute force solution - useful for implementing and exploring the problem, but also showing just how hopeless it is to brute force the solution.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
$ cat problem254_naive.py&lt;br /&gt;
&amp;quot;&amp;quot;&amp;quot;&lt;br /&gt;
Project Euler Problem 254:&lt;br /&gt;
Sum of Digit Factorials&lt;br /&gt;
&lt;br /&gt;
Naive solution: this is the most &amp;quot;obvious&amp;quot; way&lt;br /&gt;
to implement a solution, and accordingly, it will&lt;br /&gt;
take longer than the heat death of the universe.&lt;br /&gt;
&amp;quot;&amp;quot;&amp;quot;&lt;br /&gt;
&lt;br /&gt;
# Utility:&lt;br /&gt;
&lt;br /&gt;
def split_to_digits(n):&lt;br /&gt;
    d = list(str(n))&lt;br /&gt;
    return [int(z) for z in d]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
# Factorial:&lt;br /&gt;
&lt;br /&gt;
def fact(n):&lt;br /&gt;
    if n&amp;gt;1:&lt;br /&gt;
        return n*fact_(n-1)&lt;br /&gt;
    else:&lt;br /&gt;
        return 1&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
# Sum of factorial digits&lt;br /&gt;
&lt;br /&gt;
def f(n):&lt;br /&gt;
    return sum([fact(z) for z in split_to_digits(n)])&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
# Sum of digits of sum of factorial digits&lt;br /&gt;
&lt;br /&gt;
def sf(n):&lt;br /&gt;
    return sum( split_to_digits(f(n)) )&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
# Minimum number such that sum of digits of sum of factorial digits is itself&lt;br /&gt;
&lt;br /&gt;
def g(p):&lt;br /&gt;
    n = 1&lt;br /&gt;
    sf_val = sf(n)&lt;br /&gt;
    while sf_val != p:&lt;br /&gt;
        n+=1&lt;br /&gt;
        sf_val = sf(n)&lt;br /&gt;
    return n&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
# Sum of digits of minimum number, &amp;amp;c.&lt;br /&gt;
&lt;br /&gt;
def sg(p):&lt;br /&gt;
    return sum( split_to_digits( g(p) ) )&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
# Main method:&lt;br /&gt;
&lt;br /&gt;
def test():&lt;br /&gt;
    # These tests all behave as expected&lt;br /&gt;
    print(split_to_digits(342))&lt;br /&gt;
    print(f(342))&lt;br /&gt;
    print(sf(342))&lt;br /&gt;
    print(sf(25))&lt;br /&gt;
    print(g(25))&lt;br /&gt;
    print(g(20))&lt;br /&gt;
&lt;br /&gt;
    # This test goes really fast&lt;br /&gt;
    print(sum([sg(i) for i in range(1,21)]))&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
def solve():&lt;br /&gt;
    # This gets bogged down at 40, and 44, and &amp;amp;c...&lt;br /&gt;
    summ = 0&lt;br /&gt;
    for i in range(41,44):&lt;br /&gt;
        print(&amp;quot;Loop {i}&amp;quot;.format(i=i))&lt;br /&gt;
        summ += sg(i)&lt;br /&gt;
&lt;br /&gt;
    print(&amp;quot;Final sum:&amp;quot;)&lt;br /&gt;
    print(summ)&lt;br /&gt;
&lt;br /&gt;
if __name__==&amp;quot;__main__&amp;quot;:&lt;br /&gt;
    import cProfile&lt;br /&gt;
    pr = cProfile.Profile()&lt;br /&gt;
    pr.enable()&lt;br /&gt;
    solve()&lt;br /&gt;
    pr.disable()&lt;br /&gt;
    pr.print_stats()&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=Flags=&lt;br /&gt;
&lt;br /&gt;
{{ProjectEulerFlag}}&lt;/div&gt;</summary>
		<author><name>Admin</name></author>
	</entry>
</feed>