project_euler.problem_092.sol1 ============================== .. py:module:: project_euler.problem_092.sol1 .. autoapi-nested-parse:: Project Euler Problem 092: https://projecteuler.net/problem=92 Square digit chains A number chain is created by continuously adding the square of the digits in a number to form a new number until it has been seen before. For example, 44 → 32 → 13 → 10 → 1 → 1 85 → 89 → 145 → 42 → 20 → 4 → 16 → 37 → 58 → 89 Therefore any chain that arrives at 1 or 89 will become stuck in an endless loop. What is most amazing is that EVERY starting number will eventually arrive at 1 or 89. How many starting numbers below ten million will arrive at 89? Attributes ---------- .. autoapisummary:: project_euler.problem_092.sol1.CHAINS project_euler.problem_092.sol1.DIGITS_SQUARED Functions --------- .. autoapisummary:: project_euler.problem_092.sol1.chain project_euler.problem_092.sol1.next_number project_euler.problem_092.sol1.solution Module Contents --------------- .. py:function:: chain(number: int) -> bool The function generates the chain of numbers until the next number is 1 or 89. For example, if starting number is 44, then the function generates the following chain of numbers: 44 → 32 → 13 → 10 → 1 → 1. Once the next number generated is 1 or 89, the function returns whether or not the next number generated by next_number() is 1. >>> chain(10) True >>> chain(58) False >>> chain(1) True .. py:function:: next_number(number: int) -> int Returns the next number of the chain by adding the square of each digit to form a new number. For example, if number = 12, next_number() will return 1^2 + 2^2 = 5. Therefore, 5 is the next number of the chain. >>> next_number(44) 32 >>> next_number(10) 1 >>> next_number(32) 13 .. py:function:: solution(number: int = 10000000) -> int The function returns the number of integers that end up being 89 in each chain. The function accepts a range number and the function checks all the values under value number. >>> solution(100) 80 >>> solution(10000000) 8581146 .. py:data:: CHAINS :type: list[bool | None] :value: [None, None, None, None, None, None, None, None, None, None, None, None, None, None, None, None,... .. py:data:: DIGITS_SQUARED