Шифрование:
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,
Расшифровать:
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/
Две программы смещены на 3, и они принимают ввод в форме:
<2-digit offset> <text>
Смещение должно быть 2 цифры, поэтому смещение 5 должно быть введено как 05
.
Это длинная отправка, но почти все символы без заполнения используются обеими программами . Есть много пробелов, которые, безусловно, можно вывести из игры, но я подумал, что программа будет более интересной в этом смысле.
Это изображение выделяет символы, используемые обеими программами.
объяснение
Основная конструкция, которая делает это возможным, _{} -> b~!
, позволяет произвольно пропускать символы в программе дешифрования. Как?
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
В общем, программа шифрования ничего не делает, но программа дешифрования пропускает следующую инструкцию. Это может быть расширено до_{}! -> b~!$
, что позволяет вместо этого произвольно пропускать символы в программе шифрования .
Помимо этого, большая часть остальной части программы нажимает на числа, выполняет операции с этими числами, а затем находит способы их вытолкнуть. Например, одна полезная конструкция ~~ -> ""
, которая выдает два значения для программы шифрования, но ничего не выдвигает в программе дешифрования.
> <>, 149 байт
Вот менее интересная версия, в которой используется тот факт, что не пройденные инструкции фактически являются комментариями на двухмерных языках.
Шифрование:
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
Расшифровать:
^+-~/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~^
Две программы смещены на 84 и принимают данные так же, как указано выше. Первая инструкция решает, какую половину программы выполнять, с i
(вводом) поддержанием потока программы вправо в программе шифрования и ^
перенаправлением потока программы вверх (цикл вокруг и возвращение снизу) в программе дешифрования.
объяснение
Для соответствующей половины программы шифрования (программа дешифрования аналогична):
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
Инструмент кодирования
Это не относится к остальной части поста выше, но я думал, что выложу это, потому что мне нужно его использовать: 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>