Encrypt:
ffii{{~~__:0a('0'*!.0a('0'*22(!'(~$~_:}-}$-a*}+{{if~~:i:0({}?;__:{}84{}*__({}?\__:{} _{}70{}g_{})_{}?\4__{}8*-_{}+{}80{}g_%4_{}8*{}+\\sl||||||||||||||||||||||||||||9||||||||||||||9||||||||||||||||||||||||||||||||||||||||||||||||||||9
> > >!;7f7-_{}!%_{}!<872-d_{}!&_{}!<[755(7(%~~_{}!<[55(7(_{}!*!*23a(_{}!'_{}!"55(7((~~_{}~~~o__'4'0.{{{o,
Decrypt:
iill~~""bb=3d+*3*-$13d+*3*-55+$*+"'"b=!0!'0d-!.~~li""=l=3+~!B>bb=~!;7~!-bb+~!B_bb=~!#b~!:3~!jb~!,b~!B_7bb~!;-0b~!.~!;3~!jb(7b~!;-~!.__vo < < <
##############################################################################A######################A##############################A$>:i:0b~!$(b~!$?;:50gb~!$)b~!$?^:88+:+(""b~!$?^88+:+b~!$-$-56d+b~!$*b~!$%88+:++""b~!"""rbb*7*31~~~r/
I due programmi sono sfalsati di 3 e prendono l'input del modulo:
<2-digit offset> <text>
L'offset deve essere di 2 cifre, pertanto è necessario immettere un offset di 5 come 05
.
Questa è una lunga presentazione, ma quasi tutti i caratteri non di riempimento sono utilizzati da entrambi i programmi . C'è un sacco di spazio bianco che può sicuramente essere giocato a golf, ma ho pensato che il programma sarebbe stato più interessante in questo modo.
Questa immagine evidenzia i caratteri utilizzati da entrambi i programmi.
Spiegazione
Il costrutto principale che lo rende possibile è _{} -> b~!
che consente di saltare arbitrariamente i caratteri nel programma di decrittazione. Come?
Encrypt:
_ : Mirror, but is a no-op if the program flow is horizontal
{ : Shift stack left
} : Shift stack right
Decrypt:
b : Push 11 to stack
~ : Pop top of stack
! : Skip the next instruction
Tutto sommato, il programma di crittografia non fa nulla, ma il programma di decrittazione salta l'istruzione successiva. Questo può quindi essere esteso a _{}! -> b~!$
, il che consente invece di saltare arbitrariamente i caratteri nel programma di crittografia .
A parte questo, la maggior parte del resto del programma sta spingendo i numeri, eseguendo operazioni su quei numeri e trovando il modo di farli apparire. Ad esempio, un costrutto utile è~~ -> ""
, che apre due valori per il programma di crittografia, ma non inserisce nulla nel programma di decrittazione.
> <>, 149 byte
Ecco la versione meno interessante, che utilizza il fatto che le istruzioni non passate sono effettivamente commenti in linguaggi 2D.
Encrypt:
i68*:@-a*i@@-+i~v
4:v?)g31:;?(0:i:/8
(?v48*-+03g%48*+\*
_~\of0. .1+1fo/
j*+:zq<6B99A6=qz6g
53Ji?C58/8;?r0?C5:
C?EiJ4r?<EFJ3;EtEg
:tAC5EK8l5tKK86t*i
Decrypt:
^+-~/5"V~^55" ^sk
)/k4}\(&/04|%/^/$-
|4k)-~" %(\y)-~ Q~
TsQd[%#ttt#& &[d$
_~ /of1+7..6+2fo+\
*(?^48*-$-04g%48*/
84:^?)g41:;?(0:i:\
/i68*:@-a*i@@-+i~^
I due programmi sono sfalsati di 84 e prendono l'input come sopra. La prima istruzione decide quale metà del programma eseguire, con i
(input) che mantiene il flusso del programma verso destra nel programma di crittografia, e^
reindirizzando il flusso del programma verso l'alto (facendo il giro e ritornando dal basso) nel programma di decrittazione.
Spiegazione
Per la metà pertinente del programma di crittografia (il programma di decrittografia è simile):
i read first input digit as char
68*:@-a* subtract 48 (ASCII "0") and multiply by 10, keeping another 48 on the stack
i read second input digit as char
@@-+ subtract 48 and add to 10*(first digit), giving the offset
i~ read in space and discard it
--- LOOP ---
: copy the offset
i: read input char
:0)?; check if less than 0 (i.e. EOF) and terminate if so
:13g)?v check if greater than ~ in cell (1,3) and drop down if so
48*(?v check if less than 32 and drop down if so
48*-+03g%48*+ calculate Caesar shift of the char, fetching 95 from (0,3)
of1+1. repeat loop
of0. repeat loop
Strumento di codifica
Questo non è correlato al resto del post sopra, ma ho pensato di postare questo perché ho bisogno di usarlo: P
for(var i=0;i<95;++i){var option=document.createElement("option");option.text=i;document.getElementById("offset").add(option)};function update(m){if(m==1)var code=document.getElementById("in").value;else var code=document.getElementById("out").value;var offset=parseInt(document.getElementById("offset").value);var output="";for(var i=0;i<code.length;i++){var n=code[i].charCodeAt(0);if(n<32||n>127)output+=code[i];else{var c=(n-32+offset*m)%95;output+=String.fromCharCode(c<0?c+95+32:c+32)}}if(m==1)document.getElementById("out").value=output;else document.getElementById("in").value=output};
<html><body><textarea id="in" onkeyup="update(1)" rows=5 style="width:100%"></textarea><textarea id="out" rows=5 style="width:100%" onkeyup="update(-1)"></textarea><select id="offset" onchange="update(1)"></select></body></html>