Detta kan bland annat användas för att göra listor på primtal och för att göra snabbare funktion för att finna största gemensamma delare.
Övning 2.13
Lägg till en funktion till modulen diskret_matematik för att skapa en funktion som utför primtalsuppdelning enligt nedanstående pseudokod:
def primtalsuppdelning(n): Skapa en tom lista kallad primtal sätt variabeln p till 2 så länge som p är mindre eller lika med n: om n är jämnt delbart med p: lägg till p i listan primtal dividera n med p annars : öka p med ett returnera primtal
Övning 2.14
Använd primtalsuppdelningen ovan till att göra en betydligt effektivare version av funktionen sgd(a, b). Byt ut den befintliga mot denna version. Pseudokod:
def sgd(a, b): sätt storst till det största talet av a och b samt minst till det minsta om storst jämnt delbart med minst returnera minst primtalsuppdela minst och spara resultatet i listan prim antag att största gemensamma delare, sgd är 1 för alla tal p i prim : om storst jämnt delbart med p : dela storst med p multiplicera sgd med p returnera sgd
Övning 2.15
Uppdatera main() i diskret_matematik med tester av primtalsuppdelningen och testkör.
Uppgift 2.5
Skriv ett program som hittar primtal genom att använda Eratosthenes såll.
Bild: Wikipedia
Inga kommentarer:
Skicka en kommentar