Liczba Niedotykalna to taka liczba naturalna n, która nie jest sumą wszystkich dzielników właściwych jakiejkolwiek liczby naturalnej (włączając ją samą).
Najmniejszą liczbą Niedotykalną jest liczba 2. Nie ma żadnej liczby naturalnej, której suma właściwa wynosi 2. Jedyną taką możliwością byłoby np. 2, ale jeśli liczba jest podzielna 2 to i przez 1, więc suma dzielników właściwych wyniesie wtedy dokładnie 3. Z kolei każdy dzielnik dodajemy do sumy maksymalnie raz, więc 1 i 1 jest niemożliwe.
Z kolei liczba 3 już nie może być liczbą Niedotykalną, ponieważ dzielniki liczby 4 to 2 i 1 co w sumie daje 3. Wspomniana liczba 4 też nie jest liczbą pierwszą, ponieważ jest sumą dzielników właściwych liczby 9: 4 = 1 + 3.
Liczby można ustawić w następujący ciąg: 2, 5, 52, 88, 96, 120, 124, 146, 162, 188, ..
Liczb Niedotykalnych jest nieskończenie wiele. Przypuszcza się, że istnieje tylko jedna nieparzysta liczba Niedotykalna, która ma wartość 5.
Napisz program, który znajdzie wszystkie liczby Niedotykalne w zakresie [1, n]. Program powinien wypisać wszystkie znalezione liczby na konsole.
Szukając liczb Niedotykalnych warto zadeklarować tablicę możliwych kandydatów tj. początkowo wszystkie liczby z zakresu [1, n] są potencjalnymi kandydatami. Dopiero później w trakcie obliczeń kolejne liczby zostaną wykreślone z listy. Wykreślanie będzie przebiegać następująco: dla kolejnych liczb wyliczamy sumę dzielników właściwych i jeśli taka wartość na liście nie została wykreślona to to robimy.
Istnieje jednak problem z ustaleniem zakresu liczb dla których zostanie wykonane wykreślanie. Podany wcześniej przykład z liczbą 4 wskazuje, że należy wziąć liczbę spoza zakresu [1, n]. Przypuszczalnie po wyliczeniu wszystkich liczb z zakresu [1, n2] na liście nie zostaną wykreślone jedynie liczby Niedotykalne.
Nieformalny dowód tego stwierdzenia polega na tym, że nie bierzemy w nim pod uwagę liczb pierwszych dla których suma dzielników właściwych wynosi 1. Wtedy najmniejszą sumę dzielników właściwych będzie mieć n2 jako, że dzielnikami są wtedy co najmniej 1 i n, więc jest to liczba, której nie da się już wykreślić na liście. Dla każdej poprzedniej i-tej liczbie na liście i2 < n2.
Przed przystąpieniem do wykreślania warto napisać funkcję pomocniczą do sumowania dzielników właściwych sumaDzielnikow(), która przyjmuje jeden argmument a.
(2.) Inicjalizacja sumy. Potem wyszukiwanie (3.) kolejnych dzielników od 1 do n/2 włącznie, ponieważ najmniejszy dzielnik większy od 1 to 2, więc nie ma potrzeby sprawdzać zakresu (n/2 n] w celu znalezienia dzielników. (4.) Każdy znaleziony dzielnik należy (5.) dodać do sumy. Na koniec (6.) zwraca jest wartość wyznaczonej sumy.
Na początku wyszukiwania liczb Niedotykalnych należy zadeklarować tablicę z której będzie można wykreślać liczby, które nie mogą należeć do szukanego zbioru. Początkowo wszystkie liczby powinny zostać uznane za należące.
(2. - 5.) Deklaracja tablicy i oznaczenie wszystkich jako należące. Następnie (6.) dla każdej liczby z zakresu [1, n2 + 1] (7.) wyliczamy sumę jej dzielników i (8.) jeśli to możliwe to (9.) wykreślamy tę wartość z listy. Dopiero po wykreśleniu wszystkich możliwych sum można przejść do (11. - 13.) wypisania znalezionych liczb Niedotykalnych.
Poniższy kod wczytuje od użytkownika górne ograniczenie zakresu poszukiwań, a następnie wypisuje na konsolę wszystkie znalezione liczby Niedotykalne.