• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

question-closed Liczby Pierwsze SPOJ

Object Storage Arubacloud
0 głosów
183 wizyt
pytanie zadane 13 lutego 2021 w SPOJ przez Parex Nowicjusz (200 p.)
zamknięte 13 lutego 2021 przez Parex

Napisałem program do zadania na serwisie SPOJ o liczbach pierwszych https://pl.spoj.com/problems/PRIME_T/
i program działa tak jak każe zadanie (przynajmniej tak mi się wydaje) ale cały czas mam błąd odpowiedzi. Czy byłby ktoś w stanie dać mi małą wskazówkę dlaczego. 

#include <iostream>

using namespace std;


int main()
{
	int n,x,y=0;
	for (int i = 0; i < 1; i++) {
		cin >> n;
		if (n>9999)i--;
	}
	for (int i = 0; i < n; i++) {
		cin >> x;
		if (x < 1||x>10000) {
			i--;
			continue;
		}
		if (x == 1) {
			cout << "NIE" << endl;
			continue;
		}
		for (int j = 1; j <= x; j++) {
			if (x % j == 0)y++;
		}
		if (y == 2)cout << "TAK" << endl;
		if (y > 2)cout << "NIE" << endl;
		y = 0;
	}
}

 

komentarz zamknięcia: .

1 odpowiedź

+1 głos
odpowiedź 13 lutego 2021 przez Whistleroosh Maniak (56,980 p.)
wybrane 13 lutego 2021 przez Parex
 
Najlepsza
Jest kilka błedów. Po pierwsze nie ma potrzeby sprawdzania poprawności danych wejściowych, więc możesz pozbyć się pierwszej pętli for i ifa w linii 15.

Po drugie to rozwiazanie będzie za wolne i może nie zmieścić się w limtiach czasowych. Musisz skorzystać z obserwacji, że wystarczy sprawdzać dzielniki od 2 do pierwiastka z danej liczby. Ewentualnie możesz napisać sito Erastotenesa

Podobne pytania

0 głosów
1 odpowiedź 382 wizyt
pytanie zadane 19 sierpnia 2020 w SPOJ przez Billy Użytkownik (680 p.)
0 głosów
0 odpowiedzi 376 wizyt
pytanie zadane 2 stycznia 2020 w SPOJ przez Bezk Nowicjusz (140 p.)
0 głosów
2 odpowiedzi 432 wizyt
pytanie zadane 30 lipca 2019 w SPOJ przez wjacoszek2000 Początkujący (290 p.)

92,568 zapytań

141,420 odpowiedzi

319,622 komentarzy

61,954 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...