You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 35 Next »

Læringsmål:

  • Strenger
  • Char
  • Betingelser
  • For-løkker

Pensum:

  • 3.3 Input and Output
  • 3.7 User-Defined Functions That Return a Single Value
  • 4.1 The if statement
  • 4.2 The if-else statement
  • 4.3 Nested if-else statements
  • 5.1 The for loop
  • 7.2 Operations on Strings
  • 7.3 The "is" Functions for Strings

Først litt historie:

En gang for lenge siden regjerte Julius Cæsar over Romerriket. Han var en svært suksessfull militær general og som et ledd i hans militære strategi skal han visstnok ha benyttet seg av det vi idag kaller for et Cæsarschiffer. Dette er en veldig enkel form for kryptering der hver bokstav i klarteksten erstattes med en annen bokstav et gitt antall steg lenger ut i alfabetet. For eksempel hvis vi skal skrive bokstaven A i cæsarchiffer og bruker en såkalt steglengde eller "nøkkel" på 3, vil vi få ut D.

Et eksempel på det engelske alfabetet og dets cæsarchiffer med nøkkel på 3:
 
Klartekst: ABCDEFGHIJKLMNOPQRSTUVWXYZ
Chiffertekst: DEFGHIJKLMNOPQRSTUVWXYZABC
 
Som du kan se så hopper man tilbake til start når man kommer til slutten av alfabetet, slik at neste bokstav etter Z blir A etc.


a)

 
Lag funksjonen caesar(word, key)som tar inn en bokstav word og forskyver hver bokstav (som er av typen char) i word med key antall tegn i alfabetet.
Bokstavene skal forskyves til høyre dersom step er positiv og til venstre dersom den er negativ.
Chifferet skal kun kjøres på bokstaver i det engelske alfabetet, dvs. a-z. Du kan anta at det kun tas inn små bokstaver.

Eksempel på kjøring
>> caesar('terningen', 3)
ans =

    'whuqlqjhq'

 

 

b) 

Utvid nå funksjonen du lagde i deloppgave a) til å kunne håndtere setninger (hvis den ikke allerede gjør det).

 

Dersom funksjonen din støter på andre tegn enn a-z, slik som ,.-;: og mellomrom osv. skal disse bare ignoreres. Her kan continue komme til nytte.

 

Lag deretter en funksjon plaintext(word, key) som tar inn et cæsarchiffer og dekrypterer dette. Dette er med andre ord en slags omvendt funksjon av caesar().

 

Finner du en måte å gjøre dette på, uten så skrive så mye ny kode?



Eksempel på kjøring
>> caesar('terningen er kastet.', 3)
ans =

    'whuqlqjhq hu ndvwhw.'
 
>> plaintext('whuqlqjhq hu ndvwhw.', 3)
ans =

 'terningen er kastet.'

 

 

c)

Lag funksjonen safeTalk(). Den skal gi brukeren valget mellom kryptering eller dekryptering. Deretter skal den be brukeren om en tekstreng og antall steg. Den skal returnere den krypterte eller dekrypterte strengen.

Eksempel på kjøring:

    >> safeTalk
    Vil du kryptere(k) eller dekryptere(d):
    k
    Hva vil du kryptere:
    tusenfryd
    Hvor mange steg skal ordet skiftes?:
    1

    ans =

    uvtfogsze

        Merk: funksjonen må også ta hensyn til at brukeren vil kryptere/dekryptere setninger. Hva gjør man da med mellomrom, komma, punktum osv.?

d)

Dekrypter setningen under. 
Hint: Dette kan løses ved å finne den hyppigste bokstaven i strengen. Avstanden fra e til denne bokstaven er da forskyvningen.  

zmumujmz, zmumujmz, bpm nqnbp wn vwdmujmz, bpm ocvxwelmz bzmiawv ivl xtwb. q svwe wn vw zmiawv epg bpm ocvxwelmz bzmiawv apwctl mdmz jm nwzowb.
  • No labels