IOCCCとは - わかりやすく解説 Weblio辞書 (original) (raw)

The International Obfuscated C Code ContestIOCCC, 国際難読化[1]Cコードコンテスト)は、故意に難解なC言語のプログラムを書き、その読みにくさと複雑さを競うというハッカー奇祭プログラミングコンテスト)である。

一般的に読みにくいコードであれば評価が高いが、目にした瞬間のインパクトや、コードの汚さに反して実行結果の美しさなど、さまざまな要因でアーティスティックなものが選ばれる。多くの作品は一見するとC言語のコードに見えず、コード全体がアスキーアートになっているものなどが典型的である。

第一回大会は1984年に行われ、以降2006年まで年1回のペースで入賞者が発表された。以降中断と再開が繰り返され、2011年から2015年まで、2018年から2020年までそれぞれ年1回のペースで開催されている[3]Perl作者のラリー・ウォールKornShell作者のデビッド・コーン(英語版)などの著名な業界関係者も参加している。

このようなコンテストを開催しようと思ったきっかけは、初期の開催者ランドン・カート・ノル(英語版)とLarry Basselが、Bourne Shellのソースコード[4]と、初期のBSDのfinger(Fingerプロトコル)のソースコードを見たことだという[5]

main() { printf(&unix["\021%six\012\0"],(unix)["have"]+"fun"-0x60);}

#define _ -F<00||--F-OO--; int F=00,OO=00;main(){F_OO();printf("%1.3f\n",4.*-F/OO/OO);}F_OO() { --- --------_ ----------- ------------- --------------_ --------------_ --------------- --------------- --------------- --------------- --------------_ --------------_ ------------- ----------- ------- --- }

#include <math.h> #include <sys/time.h> #include <X11/Xlib.h> #include <X11/keysym.h> double L ,o ,P ,=dt,T,Z,D=1,d, s[999],E,h= 8,I, J,K,w[999],M,m,O ,n[999],j=33e-3,i= 1E3,r,t, u,v ,W,S= 74.5,l=221,X=7.26, a,B,A=32.2,c, F,H; int N,q, C, y,p,U; Window z; char f[52] ; GC k; main(){ Displaye= XOpenDisplay( 0); z=RootWindow(e,0); for (XSetForeground(e,k=XCreateGC (e,z,0,0),BlackPixel(e,0)) ; scanf("%lf%lf%lf",y +n,w+y, y+s)+1; y ++); XSelectInput(e,z= XCreateSimpleWindow(e,z,0,0,400,400, 0,0,WhitePixel(e,0) ),KeyPressMask); for(XMapWindow(e,z); ; T=sin(O)){ struct timeval G={ 0,dt1e6} ; K= cos(j); N=1e4; M+= H*; Z=DK; F+=_P; r=EK; W=cos( O); m=KW; H=KT; O+=DF/ K+d/KE*; B= sin(j); a=BTD-EW; XClearWindow(e,z); t=TE+ DBW; j+=d*_D-_FE; P=WEB-TD; for (o+=(I=DW+E TB,Ed/K B+v+B/KFD); p<y; ){ T=p[s]+i; E=c-p[w]; D=n[p]-L; K=D*m-B*T-H*E; if(p [n]+w[ p]+p[s ]== 0|K <fabs(W=T*r-I*E +D*P) |fabs(D=t *D+Z *T-a *E)> K)N=1e4; else{ q=W/K *4E2+2e2; C= 2E2+4e2/ K *D; N-1E4&& XDrawLine(e ,z,k,N ,U,q,C); N=q; U=C; } ++p; } L+=* (Xt +PM+ml); T=XX+ ll+M M; XDrawString(e,z,k ,20,380,f,17); D=v/l15; i+=(B l-Mr -XZ)_; for(; XPending(e); u =CS!=N){ XEvent z; XNextEvent(e ,&z); ++((N=XLookupKeysym (&z.xkey,0))-IT? N-LT? UP-N?& E:& J:& u: &h); --( DN -N? N-DT ?N== RT?&u: & W:&h:&J ); } m=15F/l; c+=(I=M/ l,lH +IM+aX)_; H =Ar+vX-Fl+( E=.1+X4.9/l,t =Tm/32-IT/24 )/S; K=FM+( h* 1e4/l-(T+ E5TE)/3e2 )/S-Xd-BA; a=2.63 /ld; X+=( dl-T/S (.19E +a .64+J/1e3 )-M v +A Z); l += K *; W=d; sprintf(f, "%5d %3d" "%7d",p =l /1.7,(C=9E3+ O*57.3)%0550,(int)i); d+=T(.45-14/l* X-a130-J .14)_/125e2+Fv; P=(T(47 I-m 52+E94 D-t.38+u.21E) /1e2+W 179v)/2312; select(p=0,0,0,0,&G); v-=( WF-T*(.63m-I.086+mE19-D25-.11u )/107e2)*; D=cos(o); E=sin(o); } }