Skillnad mellan versioner av "Övningar 10 (Algoritmer)"

Från Mathonline
Hoppa till: navigering, sök
m
m
 
(3 mellanliggande versioner av samma användare visas inte)
Rad 28: Rad 28:
 
* &nbsp; Mata in klassen [[Kap_4_Tillämpningar#Klassen_EncryptStr|<b><span style="color:blue">EncryptStr</span></b>]] och programmet [[Kap_4_Tillämpningar#Programmet_EncryptStrTest|<b><span style="color:blue">EncryptStrTest</span></b>]]. Kompilera och kör.
 
* &nbsp; Mata in klassen [[Kap_4_Tillämpningar#Klassen_EncryptStr|<b><span style="color:blue">EncryptStr</span></b>]] och programmet [[Kap_4_Tillämpningar#Programmet_EncryptStrTest|<b><span style="color:blue">EncryptStrTest</span></b>]]. Kompilera och kör.
 
* &nbsp; Mata in klassen [[Kap_4_Tillämpningar#Klassen_EncryptChar|<b><span style="color:blue">EncryptChar</span></b>]] och programmet [[Kap_4_Tillämpningar#Programmet_EncryptCharTest|<b><span style="color:blue">EncryptCharTest</span></b>]]. Kompilera och kör.
 
* &nbsp; Mata in klassen [[Kap_4_Tillämpningar#Klassen_EncryptChar|<b><span style="color:blue">EncryptChar</span></b>]] och programmet [[Kap_4_Tillämpningar#Programmet_EncryptCharTest|<b><span style="color:blue">EncryptCharTest</span></b>]]. Kompilera och kör.
* &nbsp; Läs om <b><span style="color:red">Kryptering av strängar</span></b> i [http://www.mathonline.se/Progr_3/2%20Boken%20Progr_3_Cs.pdf <b><span style="color:blue">kursboken</span></b>], sid 84-86.
+
* &nbsp; Läs om <b><span style="color:red">Kryptering av strängar</span></b> i [http://mathonline.se:1802/Boken%20Alg%20Datastr%20Design.pdf <b><span style="color:blue">kursboken</span></b>], sid 135-137.
* &nbsp; Läs om <b><span style="color:red">Kryptering av text, teckenvis</span></b> i [http://www.mathonline.se/Progr_3/2%20Boken%20Progr_3_Cs.pdf <b><span style="color:blue">kursboken</span></b>], sid 87-89.
+
* &nbsp; Läs om <b><span style="color:red">Kryptering av text, teckenvis</span></b> i [http://mathonline.se:1802/Boken%20Alg%20Datastr%20Design.pdf <b><span style="color:blue">kursboken</span></b>], sid 138-140.
* &nbsp; Läs om <b><span style="color:red">Referens som parameter och returvärde</span></b> i [http://www.mathonline.se/Progr_3/2%20Boken%20Progr_3_Cs.pdf <b><span style="color:blue">kursboken</span></b>], sid 84.
+
* &nbsp; Läs om <b><span style="color:red">Referens som parameter och returvärde</span></b> i [http://mathonline.se:1802/Boken%20Alg%20Datastr%20Design.pdf <b><span style="color:blue">kursboken</span></b>], sid 135.
 
* &nbsp; I metoden Encrypt(), klassen EncryptStr, finns satsen: ch = (char)(ch + n); Undersök följande fråga:
 
* &nbsp; I metoden Encrypt(), klassen EncryptStr, finns satsen: ch = (char)(ch + n); Undersök följande fråga:
 
&nbsp; &nbsp; &nbsp; &nbsp; Varför måste (ch + n) explicit konverteras till char, när variabeln ch redan är deklarerad till char?
 
&nbsp; &nbsp; &nbsp; &nbsp; Varför måste (ch + n) explicit konverteras till char, när variabeln ch redan är deklarerad till char?
Rad 42: Rad 42:
 
<big><b><span style="color:red">Kryptering av sträng med klassen String</span></b></big>
 
<big><b><span style="color:red">Kryptering av sträng med klassen String</span></b></big>
  
Vidareutveckla krypteringsalgoritmen i [[3.4_Kryptering_av_strängar#Klassen EncryptStr|<b><span style="color:blue">Klassen EncryptStr</span></b>]].  
+
Vidareutveckla krypteringsalgoritmen i [[Kap_4_Tillämpningar#Klassen_EncryptStr|<b><span style="color:blue">Klassen EncryptStr</span></b>]].  
 
* &nbsp; Modifiera klassen <b>EncryptStr</b> till en ny klass <b>EncryptStr_Fkt</b> så här:
 
* &nbsp; Modifiera klassen <b>EncryptStr</b> till en ny klass <b>EncryptStr_Fkt</b> så här:
 
* &nbsp; Modifiera metoden <b>Encrypt(String t, int n)</b> till <b>Encrypt(String t, int k, int m)</b>.
 
* &nbsp; Modifiera metoden <b>Encrypt(String t, int n)</b> till <b>Encrypt(String t, int k, int m)</b>.
Rad 57: Rad 57:
 
<div class="ovnA">
 
<div class="ovnA">
 
<big>
 
<big>
<big><b><span style="color:red">Kryptering av text med arrayen char[]</span></b></big>
+
<big><b><span style="color:red">Kryptering av text med arrayen char[ ]</span></b></big>
  
Vidareutveckla krypteringsalgoritmen i [[3.5_Kryptering_av_text,_teckenvis#Klassen EncryptChar|<b><span style="color:blue">Klassen EncryptChar</span></b>]].  
+
Vidareutveckla krypteringsalgoritmen i [[Kap_4_Tillämpningar#Klassen_EncryptChar|<b><span style="color:blue">Klassen EncryptChar</span></b>]].  
 
* &nbsp; Modifiera klassen <b>EncryptChar</b> till en ny klass <b>EncryptChar_Fkt</b> så här:
 
* &nbsp; Modifiera klassen <b>EncryptChar</b> till en ny klass <b>EncryptChar_Fkt</b> så här:
 
* &nbsp; Modifiera metoden <b>Encrypt(char[ ] t, int n)</b> till <b>Encrypt(char[ ] t, int k, int m)</b>.
 
* &nbsp; Modifiera metoden <b>Encrypt(char[ ] t, int n)</b> till <b>Encrypt(char[ ] t, int k, int m)</b>.

Nuvarande version från 4 november 2022 kl. 13.24

        <<  Agenda          Kursens planering          Genomgång          Dagens övningar          Nästa lektion  >>      


Dagens övningar

Fortsätt att arbeta med:

\( \quad \) \( \quad \)

Rekommendation: Öppna ett textdokument.

Skriv ned dina svar. Ingen inlämning krävs.

Arbeta gärna gruppvis.


  •   Mata in klassen EncryptStr och programmet EncryptStrTest. Kompilera och kör.
  •   Mata in klassen EncryptChar och programmet EncryptCharTest. Kompilera och kör.
  •   Läs om Kryptering av strängar i kursboken, sid 135-137.
  •   Läs om Kryptering av text, teckenvis i kursboken, sid 138-140.
  •   Läs om Referens som parameter och returvärde i kursboken, sid 135.
  •   I metoden Encrypt(), klassen EncryptStr, finns satsen: ch = (char)(ch + n); Undersök följande fråga:

        Varför måste (ch + n) explicit konverteras till char, när variabeln ch redan är deklarerad till char?

  •   Lös uppgifterna nedan:


Kryptering av sträng med klassen String

Vidareutveckla krypteringsalgoritmen i Klassen EncryptStr.

  •   Modifiera klassen EncryptStr till en ny klass EncryptStr_Fkt så här:
  •   Modifiera metoden Encrypt(String t, int n) till Encrypt(String t, int k, int m).
  •   Definiera krypteringen av tecknen med en linjär funktion y = k x + m, dvs:
  •   Ersätt satsen ch = (char)(ch + n); med ch = (char)(k*ch + m);
  •   Lägg till en ny metod Decrypt(String t, int k, int m) som dekrypterar tecknen med

        den inversa funktionen y = (x - m) / k dvs: ch = (char)((ch - m)/k);

  •   Anropa båda metoderna från Main() genom att skicka värdena 2 till k och -5 till m.

        Dvs krypteringsfunktionen blir y = 2 x - 5 och dekrypteringsfunktionen y = (x + 5) / 2


Kryptering av text med arrayen char[ ]

Vidareutveckla krypteringsalgoritmen i Klassen EncryptChar.

  •   Modifiera klassen EncryptChar till en ny klass EncryptChar_Fkt så här:
  •   Modifiera metoden Encrypt(char[ ] t, int n) till Encrypt(char[ ] t, int k, int m).
  •   Definiera krypteringen av tecknen med en linjär funktion y = k x + m, dvs:
  •   Ersätt satsen t[i] = (char) (t[i] + n); med t[i] = (char) (k*t[i] + m);
  •   Lägg till en ny metod Decrypt(char[ ] t, int k, int m) som dekrypterar tecknen med

        den inversa funktionen y = (x - m) / k dvs: t[i] = (char) ((t[i] - m)/k);

  •   Anropa båda metoderna från Main() genom att skicka värdena 3 till k och -40 till m.

        Dvs krypteringsfunktionen blir y = 3 x - 40 och dekrypteringsfunktionen y = (x + 40) / 3








Copyright © 2022 TechPages AB. All Rights Reserved.