I don't need to list all the proper divisors; I just want to compute their sum. While checking and summing up all proper divisors isn't an issue for small numbers, it becomes significantly slower for larger numbers. Any suggestions? Thanks!
8 Answers
If the prime factorization of $n$ is $$n=\prod_k p_k^{a_k},$$ where the $p_k$ are the distinct prime factors and the $a_k$ are the positive integer exponents, the sum of all the positive integer factors is $$\prod_k\left(\sum_{i=0}^{a_k}p_k^i\right).$$
For example, the sum of all of the factors of $120=2^3\cdot3\cdot5$ is $$(1+2+2^2+2^3)(1+3)(1+5)=15\cdot4\cdot6=360.$$
For proper factors, subtract $n$ from this sum. This may or may not be faster, depending on the number and how you'd get the prime factorization, but this is the typical technique for high school contest problems of this sort.
-
@Issac: Thank you! In fact, I thought of prime factorization, but the algorithm for factorization is not fast too. – roxrook Feb 18 '11 at 23:10
-
2The sum of divisors can also be written using $\sum_{i=0}^{a_k}p_k^i = (p_k^{a_k + 1})/(p_k - 1)$ for the individual factors, as may be seen from the PlanetMath article: http://planetmath.org/encyclopedia/FormulaForSumOfDivisors.html – hardmath Feb 18 '11 at 23:18
-
12@hardmath: Absolutely—each sum is the sum of a geometric series (though I think it should probably be $$\prod_k\left(\sum_{i=0}^{a_k}p_k^i\right)=\prod_k\frac{p_k^{a_k + 1}-1}{p_k - 1}$$ (add $-1$ in the numerator). – Isaac Feb 18 '11 at 23:41
-
1Yes, I miss preview mode in comments... – hardmath Feb 19 '11 at 21:19
-
3can anyone explain why this works? – अज्ञ May 31 '16 at 11:42
-
2@aksam: Take the example of 120, as in the answer. A positive integer factor is the product of 0, 1, 2, or 3 factors of 2, 0 or 1 factor of 3, and 0 or 1 factor of 5. Expanding $(1+2+2^2+2^3)(1+3)(1+5)$ gives the sum of all possible such products. – Isaac May 31 '16 at 18:42
-
@Isaac sorry I am still not clear, I mean to say how we can guarantee that the result obtained is the sum of all the divisors of n, is there any intuitive way to think of? – अज्ञ Jun 01 '16 at 07:39
-
@aksam this helped me - http://mathschallenge.net/library/number/sum_of_divisors – Saurabh Goyal Jul 09 '16 at 16:11
-
These numbers seem to occur in the results of the riemann zeta function. What's going on with that? How does the result go "linear-number linear-number exponential exponential linear-factor linear-factor..." What kind of pattern is that? How are you suppose to anticipate $2^335?$ – Aug 05 '17 at 06:58
-
Could anyone explain why the following step works? I understand that we can express a divisor $d$ of $n$ as $$d = \prod_{i=1}^k p_i^{\mu_i}, where \ 0 \leq \mu_i \leq a_i $$ but how can we then go from "the sum over all divisors becomes the sum over all possible choices for the $\mu_i$'s" to this formula? $$\sum_{d|n} d = \sum_{0 \leq \mu_i \leq a_i} \prod p_i^{\mu_i}$$ – ensbana Jul 07 '18 at 09:43
Just because it is interesting:
There is actually a (less known) recursive formula for calculating $\sigma(n)$, the sum of the divisors of $n$.
$$\sigma(n) = \sigma(n-1) + \sigma(n-2) - \sigma(n-5) - \sigma(n-7) + \sigma(n-12) +\sigma(n-15) + ..$$ Here $1,2,5,7,...$ is the sequence of generalized pentagonal numbers $\frac{3n^2-n}{2}$ for $n = 1,-1,2,-2,...$ and the signs are repetitions of $1,1,-1,-1$. The summation continues until you try to calculate $\sigma$ of something negative. However, if $\sigma(0)$ occurs in the summation (this happens precisely when $n$ is a generalized pentagonal number), it should be replaced by $n$ itself. In other words $$ \sigma(n) = \sum_{i\in \mathbb Z_0} (-1)^{i+1}\left( \sigma(n - \tfrac{3i^2-i}{2}) + \delta(n,\tfrac{3i^2-i}{2})n \right), $$ where we set $\sigma(i) = 0$ for $i\leq 0$ and $\delta(\cdot,\cdot)$ is the Kronecker delta.
Note that calculating $\sigma(n)$ requires $\sigma(n-1)$ already, therefore its complexity is at least $\mathcal O(n)$, which makes it kind of useless for practical purposes. Note however the lack of reference to divisibility in this formula, which makes it a bit miraculous and therefore worth mentioning.
Here's a reference to the Euler's paper from 1751.
- 8,987
-
Many thanks for a great information. Although I don't understand it completely now, I will go back to it when I'm ready. – roxrook Feb 19 '11 at 04:58
-
Is the formula correct? I get a negative sign for i=1 in your sum, and $\sigma(n-\frac{3 1^2 - 1}{2})$ has a positive sign in your first equation. Most likely, I made a mistake... (I tried it by hand using n=6). – Unapiedra Oct 11 '13 at 17:25
-
"it should be replaced by $n$ itself". So do that: $\delta(...) n$, also I find that it should be $(-1)^{i+1}$. Doing this gives me correct result for all my test cases. – Unapiedra Oct 11 '13 at 23:08
-
2Thanks for pointing out this little gem! And it's far from useless. For certain purposes - like the SPOJ DIVSUM challenge where the sigma function needs to be computed in bulk - all lower sigma values are available via memoisation (caching), so that the computation of any one value needs nothing more than addition and table lookups. I coded it for SPOJ DIVSUM and it passed with flying colours (0.5 s for computing half a million sigmas, compared to one minute for one two-digit sigma w/o memoisation). – DarthGizka Feb 20 '16 at 00:31
-
-
-
1@DarthGizka It was found that using a sieve algorithm is much faster than that approach. – Paul Evans Aug 29 '21 at 15:15
If $$n = a^p × b^q × c^r × \ldots$$ then total number of divisors $ = (p + 1)(q + 1)(r + 1)\ldots$
sum of divisors $\Large = [\frac{a^{(p+1)}-1}{(a \ – \ 1)} × \frac{b^{(q+1)}-1}{(b \ – \ 1)} × \frac{c^{(r+1)}-1}{(c \ – \ 1)}\ldots]$
for e.g. the divisors of $8064$ $$8064 = 2^7 × 3^2 × 7^1$$
total number of divisors $= (7+1)(2+1)(1+1) = 48$
sum of divisors $= [\frac{2^{(7+1)} –1]}{(2–1)} × \frac{3^{(2+1)} –1}{(3–1)} ×\frac{7^{(1+1)} –1}{(7–1)}]$
$= 255 × 7 × 8 = 26520$
P.S. Note that a divisor of an integer is also called a factor.
- 588
- 361
Here's a very simple formula:
$$\sum_{i=1}^n \; i\mathbin{\cdot}((\mathop{\text{sgn}}(n/i-\lfloor n/i\rfloor)+1)\mathbin{\text{mod}}2)$$
(for the sake of brevity, one can write $\mathop{\text{frac}}(n/i)$ instead of $n/i-\lfloor n/i\rfloor$).
This is a way to get the function $\text{sigma}(n)$, which generates OEIS's series A000203.
What you want is the function that generates A001065, whose formula is a slight modification of the one above (and with half its computational burden):
$$\sum_{i=1}^{n/2} \; i\mathbin{\cdot}((\mathop{\text{sgn}}(n/i-\lfloor n/i\rfloor)+1)\mathbin{\text{mod}}2)$$
That's it. Straight and easy.
-
I'm sorry but what does sign mean in this context? E.g. $sgn(1/3)$ is what? – Vincent Apr 24 '20 at 10:59
-
Hello @Vincent, $\mathop{\text{sgn}}(1/3)=1$. https://en.wikipedia.org/wiki/Sign_function – Flavio Zelazek Apr 24 '20 at 14:44
-
But aren't all of them 1 then? I don't see any negative numbers appearing in the sum – Vincent Apr 25 '20 at 08:17
-
1Hi again @Vincent, I hope this can help (the yellow part is editable). – Flavio Zelazek Apr 25 '20 at 13:16
-
Hi yes, thank you, it makes sense now. I forgot that the sign is not just $1$ or $-1$ but also sometimes 0 – Vincent Apr 25 '20 at 16:00
-
The formulae are wrong, see this https://math.stackexchange.com/a/841179/542895 – Black Mild Dec 30 '23 at 08:08
If you want numerical values then the calculator at the site below will list all divisors of a given positive integer, the number of divisors and their sum. It also has links to calculators for other number theory functions such as Euler's totient function.
http://www.javascripter.net/math/calculators/divisorscalculator.htm
- 295
The other answers already talk about the basic formula, but there is a nice little trick if you're going into extremes:
say you have a very large exponent (that you normally wouldn't calculate by hand, but suppose even a computer struggles with it), like $2^x$ where x ~ $10^9$
You can actually reduce this to $log(n)$ operations.
For a shorter demonstration: sum of divisors of $x^7$. Normally you would calculate each value of $x^n$ and sum them. However, a faster way (not so noticeable for such a small exponent) is:
$x^0+x^1+x^2+x^3+x^4+x^5+x^6+x^7$ $=(x^0+x^1+x^2+x^3)*(1+x^4)$ $=(x^0+x^1)*(1+x^2)*(1+x^4)$
This works very nice for numbers such as 7, 15, etc. But it works for any other number too, as long as you simply add the part that you cannot include in polynomial factorization:
$x^0+x^1+...+x^{12}$ $=(x^0+x^1+x^2+x^3+x^4+x^5)*(1+x^6)+x^{12}$ $=(x^0+x^1+x^2)*(1+x^3)*(1+x^6)+x^{12}$
It's easy to write a computer program that does exactly this and it is able to sum to just about anything you can think of. $O(log(n))$ grows very slowly.
- 11
-
Sorry, missed @Sunil's answer, it's just a more mathematical explanation of mine. – sqlnoob Dec 02 '19 at 07:15
Here's a really simple formula:
$$ \sigma(x) = \sum_{n=1}^x \left| \text{sgn}(x \text{ mod } n) - 1 \right| \cdot n $$
Short explanation:
$ \text{sign}(x \text{ mod } n) $ evaluates to $0$ if $n$ is a divisor of $x$ (or evaluates to $1$ if $n$ isn't a divisor of $x$), so we have to negate it by subtracting one from it ($0\rightarrow-1$; $1\rightarrow0$) and taking the absolute value of the result. We now have either $0$ or $1$ (depending on the divisibility), which can be multiplied by $n$ to get $0$ or $n$.
- 155
- 11
The typical brute foce approach in, say, C language:
public int divisorSum(int n){
int sum=0;
for(int i=1; i<= n; i++){
if(n % i == 0){
sum +=i;
}
}
return sum;
}
-
7It is a stack exchange for mathematics not for c-programming.So please write it in terms of mathematics language. – Ripan Saha Jun 27 '15 at 14:24
-
2
-
1Not to mention that it's not even proper C. The use of
publicmakes it look like Java. – Indiana Kernick Sep 23 '20 at 01:28