암호화 :
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 바이트
전달되지 않은 명령어가 2D 언어로 효과적으로 주석 처리된다는 사실을 사용하는 덜 흥미로운 버전이 있습니다.
암호화 :
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
코딩 툴
이것은 위의 나머지 게시물과 관련이 없지만 사용해야하기 때문에 게시 할 것이라고 생각했습니다.
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>