Diskuze: Jiné napsání programu na hledání prvočísel
V předchozím kvízu, Online test znalostí Java, jsme si ověřili nabyté zkušenosti z kurzu.
Člen
Zobrazeno 7 zpráv z 7.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí Java, jsme si ověřili nabyté zkušenosti z kurzu.
Ahoj, neviem či to presne chápem, ale rozpísal som ti to ako najlepšie viem
// použitie if
// príklad 1
if(x > y)
{
// tu vložíš kód, ktorý chceš aby sa spracoval, keď bude splnená podmienka(x>y)
}
// príklad 2
if(!(x > y))
{
// tu vložíš kód, ktorý chceš aby sa spracoval, keď NEbude splnená podmienka(x>y)
// táto podmienka sa dá tiež napísať ako if((x>y)==false), to znamená že podmienka platí ak x NIE je väčšie ako y
}
// KONKRÉTNE PRÍKLADY
//príklad1
if(5>3)
{
vypis "podmienka platí"
}
VÝSLEDOK:
vypíše sa ti "podmienka platí"
//príklad 2
if((5>3)==false)
{
vypis "podmienka NEplatí"
}
VÝSLEDOK:
nevypíše sa ti nič, pretože platí že 5>3
//príklad 3
if((2>3)==false)
{
vypis "podmienka NEplatí"
}
VÝSLEDOK:
vypíše sa ti "podmienka NEplatí"
Dúfam, že ti to pomože, ak by ti to nebolo ešte jasné, tak napíš.
Tomuhle rozumím , ale ...
Pokud použiju tohle zapsání pro přepsání programu tak mi to bude dávat chyby na nekompatibilní int s boolean atd...
příklad int a,b;
for(a=0;a<100;a++)
{for(b=2;b<=(a/b);b++)
if(!(a%b)==0)
System.out.println(a);}
jde mi o to jestli to jde takto jen pomocí podmínek zapsat aby to vybralo daná prvočísla a nehádali se podmínky, protože tím vstupuji do logické hodnoty
Tohle zapsání je špatně... jen ukázka představy a jestli to jde tímto způsobem nějak zapsat .....
Ahoj, už asi chápem čo sa pýtaš. Javu ešte neviem, ale v C# som to napísal takto:
for(int a = 3; a<100; a++)
{
for (int b = 2; b<=(a/2+1); b++)
{
if(a%b == 0)
{
break;
}
if(b==(a/2+1))
{
Console.WriteLine(a);
}
}
}
Inak, existujú aj lepšie algoritmy na zistenie prvočísiel pozri tento odkaz .
Dúfam teda že som to pochopil správne a že ti to pomohlo.
Díky funguje .... akorát nechápu ten zápis ,proč toto b<=(a/2+1) a pak dole v if taky a/2+1
Můžu poprosit o slovní přepis této podmínky ? Díky
Už jsem to pochopil = nebo přesnji dokážu to přečíst a pochopil jsem
jak to funguje.
Ale jak jsi k takovému zápisu došel ? Nepochopil jsem, z čeho a podle čeho
to zapsat právě takto hlavně druhý for .... b<=(a/2+1) ,, spodní
podmínky jsou již pochopitelné
,
Ahoj, ten príklad hore som sa snažil napísať podľa vzoru ktorý si
nahral v prvom príspevku,
existuje ale lepšie a efektívnejšie riešenie.
To čo robí program vyššie je, že vezme číslo "a" a postupne skúša
čísla ("b") a ak nájde delenie bezozvyšku (a%b==0), tak to znamená, že sa
jedná o prvočíslo. Skúša ale všetky čísla až do polovice čísla a,
takže ak máme prvočíslo a = 97, tak skúša všetky čísla až do 97/2+1 =
48+1 = 49. (Každý programovací jazyk to má inak ohľadom toho ako sa
zaokrúhľuje, C# to má tak, že 5/2 = 2, a teda 97/2 = 48, ale to tu nechcem
hlbšie rozoberať). Toto počítanie je ale zbytočné dlhé, správne je
nasledujúce:
Číslo "a" je v podstate možné napísať ako "druhá odmocnina a" krát
"druhá odmocnina a".
Príklad:
Máme číslo a=100, druhá odmocnina zo 100 je 10.
Stačí na skontrolovať čísla "b" len do výšky tejto druhej odmocniny.
Je to preto, lebo:
PRÍKLAD:
Ak máme číslo 100, tak toto číslo je deliteľné bezo zvyšku len číslami:
Nám stačí len skontrolovať, či je dané číslo deliteľné bezo zvyšku celým číslom do výšky jeho druhej odmocniny, ak tomu tak nie je, jedná sa o prvočíslo.
Dúfam, že som to napísal aspoň trochu pochopiteľne, ak si predsa
potreboval to ešte vysvetliť, tak len napíš
P.S.: kód s tou druhou odmocninou tu neudávam, môžeš si to vyskúšať
sám, aspoň si to trochu precvičíš
Zobrazeno 7 zpráv z 7.