La serie de números Harshad, también conocida como números Niven, está formada por números naturales que son divisibles por la suma de sus dígitos. En otras palabras, un número Harshad es aquel que se puede dividir exactamente por la suma de sus dígitos. Por ejemplo, el número 18 es un número Harshad porque es divisible por la suma de sus dígitos (1 + 8 = 9). Los primeros términos de la serie son: 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 12, 18, 20, 21, 24, ...
C#
x
49
49
1
//Usings.
2
using System
3
4
/// <summary>
5
/// Calcula los primeros n números de Harshad.
6
/// </summary>
7
/// <param name="n">La cantidad de números de Harshad a calcular.</param>
8
/// <returns>Un array que contiene los primeros n números de Harshad.</returns>
9
public static int[] HarshadNumbers(int n)
10
{
11
if (n <= 0)
12
{
13
throw new ArgumentException("La cantidad de números debe ser mayor que cero.", nameof(n));
14
}
15
16
int[] harshad = new int[n];
17
int count = 0;
18
int number = 1;
19
20
while (count < n)
21
{
22
if (number % SumOfDigits(number) == 0)
23
{
24
harshad[count] = number;
25
count++;
26
}
27
number++;
28
}
29
30
return harshad;
31
}
32
33
/// <summary>
34
/// Calcula la suma de los dígitos de un número.
35
/// </summary>
36
/// <param name="number">El número del cual se desea calcular la suma de los dígitos.</param>
37
/// <returns>La suma de los dígitos del número.</returns>
38
private static int SumOfDigits(int number)
39
{
40
int sum = 0;
41
42
while (number != 0)
43
{
44
sum += number % 10;
45
number /= 10;
46
}
47
48
return sum;
49
}