Kezdőoldal » Számítástechnika » Programozás » Mit gondoltok a programozási...

Mit gondoltok a programozási gondolkodásomról?

Figyelt kérdés

Még viszonylag kezdő C++ programozó vagyok, és sokszor gyakorlok: nézegetek interneten feladatokat és azokat oldom meg. Sokszor találtam már magam olyan helyzetben életem során (nem feltétlenül a programozásban), hogy túlbonyolítok dolgokat, mikor azt sokkal egyszerűbben meg lehetett volna oldani. Ezért egy olyan kérdéssel fordulok hozzátok, hogy szerintetek mennyire sikerült jól ennek a feladatnak a megoldása:


Írj egy programot, amely kér a felhasználótól egy pozitív egész számot, és utána kiírja az összes, ennél a számnál kisebb olyan pozitív egész számot, amely nem prím!


Megoldásom:


#include <iostream>

using namespace std;


int Prim(int szam)

{

int oszto = 0;

for (int i=1; i<szam; i++)

{


if (szam%i == 0) oszto++;

}

if (oszto > 2) return 0;

else return 1;

}


int main()

{

int a = -1;

while (a < 0)

{

cout << "Szam: ";

cin >> a;

}

for (int i = a; i > 0; i--)

{

if (Prim(i) == 0) cout << i << endl;

}


return 0;

}



2012. máj. 31. 15:54
1 2
 1/13 iostream ***** válasza:
Ez semennyire sincs túlbonyolítva, ellenben rémes módon pazarolja a CPU időt.
2012. máj. 31. 16:38
Hasznos számodra ez a válasz?
 2/13 A kérdező kommentje:
Ehelyett milyen megoldást javasolnál?
2012. máj. 31. 16:43
 3/13 anonim ***** válasza:
53%
2012. máj. 31. 17:07
Hasznos számodra ez a válasz?
 4/13 anonim ***** válasza:

Valamivel jobb megoldas :


#include <iostream>


using namespace std;


bool isPrim(int num){


bool prim=true;


for(int i=2;i<num;i++){

if(num % i ==0){

prim=false;

break;

}

}


return prim;


}


int main()

{

int a;


do{

cin >>a;


}while(a<1);


for(int i=a;i>0;i--){

if(isPrim(i))

cout<<i <<"\n";

}


cin.clear();

cin.ignore();

cin.get();

}

2012. máj. 31. 19:47
Hasznos számodra ez a válasz?
 5/13 anonim ***** válasza:
Pl: Fermat féle állprímteszt. Nem véletlenül van az az egyetem, ott megtanítják, mi az a nagy ordó, meg ciklikus bonyolultság. A lényeg, hogy nem mindegy, hogy gyorsan akarsz prímeket keresni, vagy sokat. Természetesen a legjobb sokat gyorsan, de ez feladat függő.
2012. máj. 31. 20:51
Hasznos számodra ez a válasz?
 6/13 anonim ***** válasza:

Amit nem vett észre senki, hogy nem is azt csinálja a program amit kell, vagyis hibás.

Ha N-ig az összes nála kisebb prímet kell megkeresni akkor az Eratoszthenészi szita gyorsabb, ha nem a leggyorsabb.

Végül is hogy az összes prímet vagy összes nem prímet keressük, adott számig, szinte ugyan az a feladat.

2012. máj. 31. 22:22
Hasznos számodra ez a válasz?
 7/13 anonim ***** válasza:

Na megy a hülyeség ezerrel.. Fermat álprim teszt csak egy valószinüséget ad meg, nem tudod meg belőle, hogy biztosan prim-e(vagy nem) egy szám. Ráadásul nem egyszerü leprogramozni sem, plusz nem is ilyen nagyságrendü számokon alkalmazzák, hanem olyan nagyságrendre, amikor a hagyományos módszerek már nem használhatóak, cserébe viszont beáldozzák a teljes bizonyosságot :)


Első lépésben már az is sokat javitana a dolgon, ha csak a szám négyzetgyökéig tesztelnéd az osztókkal.


Második lépésben mondjuk átirhatnád szitálásra.


Harmadik lépésben meg csinálhatnál valamiféle cache-t az addig megtalált számokra, mert pl. a user beirja egymás után a 30-at, a 40-et, meg az 50-et, akkor a 30-nál kisebb számokra 2x fut le a teszt teljesen feleslegesen.

2012. máj. 31. 23:55
Hasznos számodra ez a válasz?
 8/13 anonim ***** válasza:
Miről beszélsz? Honnan szedsz ilyen hülyeséget, valószínűség? Ne röhögtess:D:D Fermatféle álprímteszt pár sor. Egy moduláris osztás rekurzívan hívva. Azt mondja meg, hogy a szám lehet-e prím. Ha lehet, akkor elég megnézni azt a konkrét számot, hogy prím-e. Nem értem, minek szólsz bele olyanba, amihez nem értesz.
2012. jún. 1. 05:46
Hasznos számodra ez a válasz?
 9/13 Srapnel ***** válasza:
A szitálás és cachelés az, ahol a bonyolultság kontra sebesség még tűrhető ennél a feladatnál.
2012. jún. 1. 11:42
Hasznos számodra ez a válasz?
 10/13 anonim ***** válasza:
100%

Had tegyem tisztába a dolgokat!

"Honnan szedsz ilyen hülyeséget, valószínűség? "

A Fermat-prímteszt minden prímszámról helyesen eldönti hogy prím, viszont vannak számok melyekre prímet ad pedig nem azok, ezek az ún. Fermat-álprímek. Vagyis ha azt adja vissza hogy nem prím akkor tényleg nem az. A Fermat-álprímek viszonylag ritkán fordulnak elő, vagyis ha kísérletet csinálunk a kísérlet a következő:véletlen számokat generálunk az egyenletességi hipotézisnek megfelelően, ha a generált véletlen szám prím a Fermat prímteszt szerint, akkor nagyobb valószínűséggel valóban prím mint nem az. Vagyis valamilyen valószínűséggel helyesen állapítja meg a Fermat prímteszt.


"Ráadásul nem egyszerü leprogramozni sem, plusz nem is ilyen nagyságrendü számokon alkalmazzák, hanem olyan nagyságrendre, amikor a hagyományos módszerek már nem használhatóak"

Nekem kb. 5 perc volt leprogramozni, ezt a prímtesztet unsigned int-re, óriás számokra meg elő kéne keresnem a BigInteger vagy valami ilyesmi nevű osztályomat az unsigned int-et lecserélni arra és kész.

Valóban inkább akkor használják amikor a hagyományos módszerek nem használhatóak, de inkább a Miller–Rabin-teszt-et használják ekkor.

"..cserébe viszont beáldozzák a teljes bizonyosságot"

Ez nem igaz.


Csak hogy ne a levegőbe beszéljek, vettem a fáradságot és megcsináltam a Fermat prímteszet, az Eratoszthenész szitáját, a naiv módszert ahol legfeljebb a négyzetgyökéig ellenőrzi az adott számot.

1-től 10 millióig lefuttattam a következő futási idők lettek (a kiíratás nincs benne):

Naiv módszer:

real 0m11.466s

user 0m11.449s

sys 0m0.000s


A Fermat prímteszt, naiv módszerrel biztosítva a helyességet:

real 0m7.548s

user 0m7.536s

sys 0m0.000s


Simán csak a Fermat prímteszt:

real 0m7.381s

user 0m7.368s

sys 0m0.000s


Eratoszthenész szitája:

real 0m1.059s

user 0m1.052s

sys 0m0.004s


A teljesség kedvéért megemlítem hogy amit a kérdező írt kódot nagyon pazarló, talán órák hosszáig vagy napokig futna (nem próbáltam ki)


Vagyis a nyertes nem más mint az Eratoszthenész szitája, az a sejtésem hogy ez a lehető leggyorsabb ha 1-től N-ig az összes prímet kell megkeresni, más esetben nem feltétlen.

2012. jún. 1. 16:59
Hasznos számodra ez a válasz?
1 2

Kapcsolódó kérdések:




Minden jog fenntartva © 2024, www.gyakorikerdesek.hu
GYIK | Szabályzat | Jogi nyilatkozat | Adatvédelem | Cookie beállítások | WebMinute Kft. | Facebook | Kapcsolat: info(kukac)gyakorikerdesek.hu

A weboldalon megjelenő anyagok nem minősülnek szerkesztői tartalomnak, előzetes ellenőrzésen nem esnek át, az üzemeltető véleményét nem tükrözik.
Ha kifogással szeretne élni valamely tartalommal kapcsolatban, kérjük jelezze e-mailes elérhetőségünkön!