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

Liczby pierwsze - optymalizacja

Object Storage Arubacloud
0 głosów
575 wizyt
pytanie zadane 16 lutego 2017 w SPOJ przez marcingrychtol Obywatel (1,490 p.)
edycja 17 lutego 2017 przez marcingrychtol
//usunięto rozwiązanie zadania

Zaliczyłem swoje pierwsze zadanie na SPOJu. Chciałbym jakoś zoptymalizować kod, gdyż widzę, że najszybsze wyniki mają 0.00s, a mi pokazuje 0,15s, rekordowo 0,11s - czyli całkiem sporo do skrócenia. Znalazłem na razie taki tip, żeby pętlę dzielącą wrzucić do odrębnej funkcji - ale czy to faktycznie jest w stanie przyspieszyć program kilkanaście razy?

Zamiast ostatniego ifa, miałem wcześniej switcha, który w zależności od wartości zmiennej "czypierwsza" wyrzucał odpowiedź, ale jego zmiana nic nie dała.

Czy jest jeszcze coś innego, o czym nie wiem?

 

 

2 odpowiedzi

0 głosów
odpowiedź 16 lutego 2017 przez manjaro Nałogowiec (37,390 p.)
wybrane 17 lutego 2017 przez marcingrychtol
 
Najlepsza

Zaimplementuj ten algorytm i zejdziesz do 0.00s.

komentarz 17 lutego 2017 przez marcingrychtol Obywatel (1,490 p.)
Widziałem to wcześniej, ale nie byłem pewien jak to zaimplementować. Rozumiem, że powinienem sobie utworzyć tablicę liczb pierwszych o wartościach w zakresie 0..100 i jedna więcej (bo pierwiastek z 10 000), a potem liczbę podaną do sprawdzenia dzielić kolejno nie przez i++, tylko przez wartości z tablicy, a inkrementować tylko jej indeks?
komentarz 17 lutego 2017 przez manjaro Nałogowiec (37,390 p.)
edycja 17 lutego 2017 przez manjaro

Też tak zrobiłem za pierwszym razem ale jest to trochę mało eleganckie. Lepiej to zrobić bez tworzenia ręcznie takich tablic. Przy zadaniu Dyzio zastosowałem taki kod do tworzenia tablicy miliona liczb pierwszych. Obczaj to i ewentualnie przerób. Jeżeli znajdzie liczbę która nie jest pierwsza to wpisuje do tablicy 1. Tam gdzie zostało 0 mamy liczbę pierwszą.

       unsigned int *pierwsze;
       pierwsze = new unsigned int [1000000];
 
        for (unsigned int i=2; i<=1000; i++){
          if (pierwsze[i]==0) {
              for (unsigned int j=2*i; j<=1000000; j+=i){
                  pierwsze[j]=1;
              }
          }
        }

 

komentarz 17 lutego 2017 przez marcingrychtol Obywatel (1,490 p.)
Czyli sito ma de facto nie zajmować się działaniami na liczbach, tylko "wykreślaniem" pól z tablicy, a sama tablica nie zawiera liczb pierwszych tylko ich znaczniki?
komentarz 18 lutego 2017 przez manjaro Nałogowiec (37,390 p.)
Dokładnie tak. Później możesz z taką tablicą robić co chcesz. Sumować liczby pierwsze albo zliczać ich ilość. Taka uwaga jeszcze - w tej tablicy trzeba jeszcze zmodyfikować 2 pierwsze liczby czyli pierwsze[0] i pierwsze[1] bo one nie są też pierwsze. Albo po prostu pamiętać że liczymy od pierwsze[2] bo 2 jest początkową liczbą pierwszą.
0 głosów
odpowiedź 16 lutego 2017 przez Żyrosławw Bywalec (2,300 p.)
Najlepiej byłoby wybrać lepszy algorytm, w tym najprawdopodobniej tkwi szkopuł. Rzeczy takie jak wrzucanie pętli while do innej funkcji nie poprawią szybkości działania programu, a  jedynie jego czytelność :)
komentarz 16 lutego 2017 przez marcingrychtol Obywatel (1,490 p.)
Rozumiem, że musiałbym iść raczej w jakieś twierdzenia matematyczne i szukać innego sposobu nie na poziomie programistycznym, a na ideowym?
komentarz 16 lutego 2017 przez Żyrosławw Bywalec (2,300 p.)

Jak chcesz zejść do zera to poszukaj sobie różnych testów pierwszości w necie i zaimplementuj jakiś inny. Twój jest po prostu wolny.

Tu kilka opisanych:

http://eduinf.waw.pl/inf/alg/001_search/0016.php

Podobne pytania

0 głosów
1 odpowiedź 183 wizyt
pytanie zadane 13 lutego 2021 w SPOJ przez Parex Nowicjusz (200 p.)
0 głosów
1 odpowiedź 380 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.)

92,551 zapytań

141,393 odpowiedzi

319,523 komentarzy

61,936 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!

...