Yksinkertainen salakieli

Oletko tehnyt jotain, mistä muut voisivat hyötyä. Postita vinkit tänne.
Post Reply
temu92
Web Developer
Web Developer
Posts: 1226
Joined: Mon Aug 27, 2007 9:56 pm
Location: Gamindustri
Contact:

Yksinkertainen salakieli

Post by temu92 »

Englanninkielentunnilla tuli väsättyä todella yksinkertainen salakieli ja pitihän tottakai väsätä versio tietokoneellekkin. Joten tässä olisi

Selitys miten toimii:
Ensin on kaikki kirjaimet jotka ovat salauksen avain luetellaan tyyliin

Code: Select all

ABCDEFG|HIJKLMN|OPQRSTU|VXYZÅÄÖ
HUOM!! W tarkoituksella poissa jotta jako 7 osissa onnistuu, tosin sen olisi saanut pienellä vaivalla paremmaksikin mutta se jääköön teille kotitehtäväksi :mrgreen:

Sitten otetaan vaikka sana talo
Jotta se saadaan käännettyä salakieleen tarkastellaan jokaista kirjainta

Code: Select all

T - Löytyy OPQRSTU, se on 6. kirjain. Otetaan seuraava kirjainyhdistelmä joka on VXYZÅÄÖ ja napataan sieltä kirjain Ä
Homma jatkuu vastaavasti tosin jos otetaan kirjain viimeisestä yhdistelmästä tarkasteltavaksi, salakoodattu otetaan ensimmäisestä ja päinvastoin.

Ja jotta saisit koodin purettua, tee sama homma täysin päinvastoin eli jos kirjain on otettu VXYZÅÄÖ, oikeakielinen otetaan OPQRSTU
Joten nyt sana TALO muuttuu ÄHSV
Testatkaa itse, tällä saat väsättyä hauskoja pulmia aivonystyröiden kiusaamiseen :D

Code: Select all

SCREEN 800, 200
Const CODE_ENCODE = 1
Const CODE_DECODE = -1

Const KEYWORD_COUNT = 3
Dim keyword(KEYWORD_COUNT) As String
keyword(0)="abcdefg"
keyword(1)="hijklmn"
keyword(2)="opqrstu"
keyword(3)="vxyzåäö" // W on tarkoituksella poissa koska ei niin yleinenkään kirjain

Repeat
	txt$ = Input("Write something >> ")
	If show Then
		Text 10, 20, "Original: "+orgtxt$
		Text 10, 45, "Encoded: "+encodedtxt$
		Text 10, 60, "Decoded: "+decodedtxt$
	EndIf
	If KeyHit(28) Then
		orgtxt$ = txt$
		encodedtxt$ = EncodeTxt(txt$)
		decodedtxt$ = DecodeTxt(txt$)
		show = 1
		CloseInput
	EndIf
	DrawScreen
Forever

Function EncodeTxt(txt$)
	Return CodeTxt(txt$, CODE_ENCODE)
EndFunction

Function DecodeTxt(txt$)
	Return CodeTxt(txt$, CODE_DECODE)
EndFunction

Function CodeTxt(txt$, codingStyle)
	txt$ = Lower(txt$)
	For i=1 To Len(txt$)
		letter$ = Mid(txt$, i, 1)
		If IsLetter(letter$) Then
			For x=0 To 3
				letterID = InStr(keyword(x), letter$)
				If letterID > 0 Then
					keywordID = CalcKeywordID(x, codingStyle)
					newLetter$ = Mid(keyword(keywordID), letterID, 1)
					newtxt$ = newtxt$ + newLetter$
					Exit
				EndIf
			Next x
		Else
			newtxt$ = newtxt$ + letter$
		EndIf
	Next i
	Return newtxt$
EndFunction

Function IsLetter(letter$)
	letter$ = Lower(letter$)
	ascCode = Asc(letter$)
	If (ascCode >= 97 And ascCode <= 122) Or (ascCode = 228 Or ascCode = 246 Or ascCode = 229) And ascCode <> 119 Then //poista kohta And ascCode <> 119 jos haluat myös W toimivan
		Return 1
	EndIf
	Return 0
EndFunction

Function CalcKeywordID(curID, codingStyle)
	newID = curID + codingStyle
	If newID < 0 Then Return KEYWORD_COUNT
	If newID > KEYWORD_COUNT Then Return 0
	Return newID
EndFunction
Last edited by temu92 on Thu Aug 30, 2007 7:14 pm, edited 2 times in total.
User avatar
TheDuck
Devoted Member
Posts: 632
Joined: Sun Aug 26, 2007 3:51 pm
Location: C:\Program Files\Tuusula\

Re: Yksinkertainen salakieli

Post by TheDuck »

Whö! Äffofu vu ävåp opluv =x Uötlzvä avpå aplsf ävptph =)

Suomennos: Wau! täähän on tosi hieno =P Numerot vois vielä toimia =)

Oli pakko testata... 8-)
^^
temu92
Web Developer
Web Developer
Posts: 1226
Joined: Mon Aug 27, 2007 9:56 pm
Location: Gamindustri
Contact:

Re: Yksinkertainen salakieli

Post by temu92 »

vlaka wrote:Numerot vois vielä toimia =)
Ne voit itse lisätä helposti lisäämällä rivejä tohon keywordiin
Purple
Newcomer
Posts: 7
Joined: Thu Oct 25, 2007 1:01 pm
Location: Vaasa
Contact:

Re: Yksinkertainen salakieli

Post by Purple »

Kiva
Työn alla :
- Yewi » Rpg peli. Valmis 2% ( Tuleekohan koskaan valmiiksi? :/ )
¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨¨
Purple
Bagard
Newcomer
Posts: 46
Joined: Sun Aug 26, 2007 4:56 pm
Location: Finland

Re: Yksinkertainen salakieli

Post by Bagard »

Purple wrote:Kiva
Attention:

Ei juma. Tällaisia viestejä ei sitten enää jatkossa postata ollenkaan. Tämä on sentään foorumi, joten kyllä niissä viesteissä pitää olla sisältöäkin!

Vipix

Re: Yksinkertainen salakieli

Post by Vipix »

Kiva on.
Tietäiskö kukaan millä koodilla ton koodin sais purettua?
Vipix

Re: Yksinkertainen salakieli

Post by Vipix »

Tai sellasen, että vois kopioida tekstin, suoraan Ctrl + C
Oon näissä koodiasioissa peukalo keskellä kämmentä.
temu92
Web Developer
Web Developer
Posts: 1226
Joined: Mon Aug 27, 2007 9:56 pm
Location: Gamindustri
Contact:

Re: Yksinkertainen salakieli

Post by temu92 »

Siinähä koodis on jo decrypteri valmiina joten ei tartte mitää erillisii enää kehitellä. Ja leikepöytäkomennot löytyy täältä http://www.coolbasic.com/oldforums/inde ... c=2325&hl=
User avatar
elmo123
Active Member
Posts: 153
Joined: Sun Sep 09, 2007 4:19 pm

Re: Yksinkertainen salakieli

Post by elmo123 »

temu92 wrote:Siinähä koodis on jo decrypteri valmiina joten ei tartte mitää erillisii enää kehitellä. Ja leikepöytäkomennot löytyy täältä http://www.coolbasic.com/oldforums/inde ... c=2325&hl=
1. Koodin decrypteri ei minulla ainakaan toiminut, salatusta tekstistä tuli pahempaa sotkua
2. Offtopic:Leikepöytäkomentojen latauslinkki ei toiminut :|
Kiinnostuin pelien tekemisestä ennen 1. luokkaa.
Sitten 3. luokalla tuli CB. Ja siitä se alkoi.

Blender! TF2! CB! Game Maker! Nokia-mollaus! Kitaransoitto! Breakdance! MadTracker! Minecraft!
Post Reply