Given a natural number A, I want to find all the pairs of natural numbers (B,C) so that B*C*(C+1) = A

后端 未结 3 1499
情书的邮戳
情书的邮戳 2021-02-06 08:45

What\'s the fastest way to do it?

My simple aproach:

for (C = 1;C

        
3条回答
  •  日久生厌
    2021-02-06 09:43

    Step 1: Factor A

    Step 2: Find the set S of all divisors from the prime factors of A.

    Step 3: For each divisor c in S, check if c+1 divides A too. If it does then b=A/(c*(c+1)) is a solution. (This uses that c and c+1 are coprime. Thus if both c and c+1 divide A then so does c*(c+1)).

    The complexity of this depends on the method that is used for factor A. E.g., if you implement for example Pollard-rho (which is relatively simple) then the complexity of the implementation is about O(A^0.25) in the worst case. And this still isn't the best possible answer. There are of course better factoring algorithm. Also if your input is a special case with lots of divisors, then factoring can be easy and the number of divisors is the limiting problem.

    The advantage of this method is of course that you'll spend your time on a generally useful function (i.e factorization), which will simplify solving other similar problems. My own implementation of Pollard-rho in Python needs a total of 0.03 s for the 20 examples with 15 digits posted by 6502, which is already at least a speedup of a factor 1000. More sophisticated implementations should lead to much larger improvements.

    For comparison, a quick and dirty Python implementation of the O(A^(1/3)) method proposed by Egor Skriptunoff needs 0.7s for the same list. This is of course a good result for a method that is easy to implement.

提交回复
热议问题