피에트 몬드리안 구성의 재생


23

안녕하세요,

최소한의 소스 코드 바이트에서 Piet Mondrian의 'Composition'그림 (예 : Composition # 10 )을 다시 작성하는 것이 목표입니다 .

레크리에이션에서는 실제 색상을 사용하거나 Windows 기본 16 색상 팔레트 에서 적절한 색상으로 교체 할 수 있습니다.

레크레이션은 PNG, BMP 또는 NetPBM, 파일 또는 STDOUT 또는 화면으로 직접 출력 할 수 있습니다.

레크리에이션은 512x512 이상의 해상도 여야합니다.

여가 활동은 인터넷에 접속해서는 안됩니다. 프로그램에 데이터 파일이 필요한 경우 크기가 소스 크기에 추가됩니다.

점수는 소스 파일의 크기 (바이트)입니다.

어떤 그림을 재현하고 있는지 기록하고 원본과 레크리에이션 사진을 연결하십시오.

행운을 빕니다.


1 단계 : 내장 PNG, BMP 또는 NetPBM 인코더가있는 언어를 찾습니다.
John Dvorak

6
관련 : Piet
Griffin

4
작업하기 어려운 언어입니다 ... 지금마다 NetPBM을 출력하는 Quine을 시도하지만 ... 그래. 누구나 Piet에서 Piet Mondrian을 재현 할 수 있다면 매우 감동받을 것입니다!
lochok

2
터미널 색상 이스케이프 및 블록 그리기 문자를 사용하여 캐릭터 아트를 출력 할 수 있습니까? (예 : ▃▃▌) 아니면 이것이 다른 도전으로 가장 잘 제기됩니까?
Tobia

2
@lochok 누군가가 시도에 진지하게 관심이 있다면 Piet 답변에 대한 현상금을 제공 할 것입니다.
Jerry Jeremiah

답변:


14

Tikz, 175 바이트

흑백의 컴포지션 III , 175 바이트

\documentclass[tikz]{standalone}\begin{document}\tikz{\def\b{;\draw[line width=}\def\a{)--(}\clip(1,1\a1,5\a5,5\a5,1)\b2mm](0,4\a6,4\a6,3\a4,3)\b1mm](4,0\a4,5);}\end{document}

Blogosphere에서 확인하십시오

이것은 아마도 몬드리안의 가장 미니멀리즘 작품 중 하나이며 아무도 그것을 찾지 못했다는 것에 놀랐습니다. 그러나 그것은 특히 흥미롭지 않으므로 답변에 다른 몇 가지 그림을 포함 시켰습니다.

설명

모든 tikz 답변과 관련된 약간의 래퍼가 있습니다. 래퍼는 다음과 같습니다.

\documentclass[tikz]{standalone}\begin{document}\tikz{
}\end{document}

래퍼를 지나면 \def바이트를 절약하지만 불행히도 코드를 난독 화 하는 몇 가지 명령문이 있습니다.

\def\b{;\draw[line width=}\def\a{)--(}

모든 적절한 대체를 수행하면 코드가 다음과 같이 나타납니다.

\clip(1,1)--(1,5)--(5,5)--(5,1);
\draw[line width=2mm](0,4)--(6,4)--(6,3)--(4,3);
\draw[line width=1mm](4,0)--(4,5);

첫 번째 비트는 \clip매우 중요하지만 당분간은 건너 뜁니다.

이제 빈 캔버스에 첫 번째 선을 그립니다.이 선은 다소 두껍기 때문에 [line width=2mm]두께를 2mm다음과 같이 설정합니다 .

\draw[line width=2mm](0,4)--(6,4)--(6,3)--(4,3);

이것은 몇 개의 노드를 연결하고 다음 모양을 생성합니다.

다음 \draw으로 두 번째 스트로크이지만이 스트로크는 더 얇아서 선 두께를 1mm다음과 같이 설정해야합니다 .

\draw[line width=1mm](4,0)--(4,5);

이제 그림은 다음과 같습니다.

이것은 원본과 비슷하지만 그리 좋지는 않습니다 \clip. 우리는 사용하는 \clip우리의 캔버스에서 모든 여분의 줄을 제거하고 올바른 크기로 캔버스를 설정할 수 있습니다. 캔버스 크기를 조정하면 이미지가 나타납니다.

흑백의 구성 III


노란색 패치 구성 , 214 바이트

\documentclass[tikz]{standalone}\begin{document}\tikz[line width=2mm]{\clip(1,1)rectangle(7,7);\draw(0,8)rectangle(4,3.5)rectangle(6.5,1.2)rectangle(4,0);\draw[fill=yellow](6.5,3.5)rectangle(8,2.5);}\end{document}

CyberSpace에서 평가

올 설명


파란색과 노란색의 컴포지션 II , 225 바이트

\documentclass[tikz]{standalone}\begin{document}\tikz[line width=2mm]{\clip(1,1)rectangle(7,10);\draw(8,9)rectangle(3,6)rectangle(0,0);\draw[fill=yellow](0,0)rectangle(3,2);\draw[fill=blue](0,11)rectangle(3,9);}\end{document}

Webbernetz를 통해 평가하십시오!

올 설명


빨간색의 컴포지션 B (2 번) , 232 바이트

\documentclass[tikz]{standalone}\begin{document}\tikz[line width=2mm]{\clip(1,1)rectangle(10,13);\draw[line width=1mm](1.2,5)--(1.2,9);\draw[fill=red](0,14)rectangle(5,9);\draw(0,9)rectangle(11,5)(7,0)rectangle(5,14);}\end{document}

인터넷에서 시도하십시오!

설명

첫 번째는 더 읽기 쉽게하기 위해 줄 바꿈이 삽입 된 코드입니다.

\documentclass[tikz]{standalone}
\begin{document}
\tikz[line width=2mm]{
\clip(1,1)rectangle(10,13);
\draw[line width=1mm](1.2,5)--(1.2,9);
\draw[fill=red](0,14)rectangle(5,9);
\draw(0,9)rectangle(11,5)(7,0)rectangle(5,14);
}
\end{document}

관심있는 첫 번째 명령은

\draw[fill=red](0,14)rectangle(5,9);

검은 색 외곽선이있는 빨간색 사각형을 그립니다. 그림의 왼쪽 상단에 있습니다.

그런 다음 흰색 내부와 검은 색 외곽선으로 사각형을 두 개 더 그려서 그림에 격자 패턴을 만듭니다.

\draw(0,9)rectangle(11,5)(7,0)rectangle(5,14);

그런 다음가는 선을 그립니다.

\draw[line width=1mm](1.2,5)--(1.2,9);

이미지를 적절한 크기로 자릅니다

\clip(1,1)rectangle(10,13);


빨간색, 파란색 및 노란색의 컴포지션 II , 251 바이트

\documentclass[tikz]{standalone}\begin{document}\tikz[line width=1mm]{\clip(1,1)rectangle(9,9);\draw[fill=yellow](8.5,6)--(0,6)--(8.5,6)--(8.5,2)rectangle(10,0);\draw[fill=red](3,3)rectangle(10,10);\draw[fill=blue](0,0)rectangle(3,3);}\end{document}

월드 와이드 웹에서 테스트하십시오!

설명

먼저 코드를 읽을 수 있도록 줄 바꿈을 삽입합니다.

\documentclass[tikz]{standalone}
\begin{document}
\tikz[line width=1mm]{
\clip(1,1)rectangle(9,9);
\draw[fill=yellow](8.5,6)--(0,6)--(8.5,6)--(8.5,2)rectangle(10,0);
\draw[fill=red](3,3)rectangle(10,10);
\draw[fill=blue](0,0)rectangle(3,3);
}
\end{document}

첫 번째 중요 라인은 다음과 같습니다.

\draw[fill=yellow](8.5,6)--(0,6)--(8.5,6)--(8.5,2)rectangle(10,0);

이것은 다음 모양을 그립니다.

이 이상한 모양은 오른쪽 아래 모서리에있는 노란색 사각형과 색이 지정된 사각형의 가장자리가 아닌 두 개의 선입니다. 다음으로 빨간색 사각형을 삽입하고 마지막 모양으로 만든 추가 선을 덮습니다.

\draw[fill=red](3,3)rectangle(10,10);

이것은 다음과 같이 나타납니다.

이제 파란색 사각형을 삽입합니다 :

\draw[fill=blue](0,0)rectangle(3,3);

이제 남은 것은 이미지를 사용하여 이미지의 불필요한 부분을 모두 잘라내는 것입니다. \clip

\clip(1,1)rectangle(10,10);

적색, 청색 및 황색의 조성물 II


컴포지션 II , 308 바이트

\documentclass[tikz]{standalone}\begin{document}\tikz[line width=2mm]{\clip(1,1)rectangle(12.6,13);\draw(0,0)rectangle(10,4)rectangle(2,12)--(0,12);\draw[fill=red](10,1.6)rectangle(14,0);\draw[fill=yellow](6,12)rectangle(10,14);\draw[fill=blue](0,4)rectangle(2,8);\fill(10,10)rectangle(14,14);}\end{document}

Information-Super-Highway 에서 확인하십시오

올 설명


12

Mathematica 202 287 바이트

재미로! 330 바이트 : 제목에 "Boogie Woogie"가있는 Mondrian

Column[{"Boogie Woogie", Grid[{{"",i["",b->Red],\[SpanFromLeft]},{"",\[SpanFromAbove],\[SpanFromBoth]},{i["",b->Blue],"",""},{\[SpanFromAbove],\[SpanFromAbove],i["",b -> Yellow]}},Dividers->{{2->t@5,3->t@6},{2->t@9,3->t@7,4->t@6}},ItemSize->{{1->3,2->9,3->1},{1->6,2->6,3->2,4->2}}]},Alignment->Center]

여기에 이미지 설명을 입력하십시오


실제 제출 [287 바이트]

\[SpanFromLeft]비슷한 표현은 대략 85 바이트를 차지합니다. 수학에서 이러한 각 표현에는 하나의 문자 기호가 있습니다.

t=Thickness;b=Background;i=Item;
Grid[{{"",i["",b->Red], \[SpanFromLeft]},{"",\[SpanFromAbove],\[SpanFromBoth]},{i["",b->Blue],"",""},{\[SpanFromAbove],\[SpanFromAbove],i[ "",b->Yellow]}},
Dividers->{{2->t@5, 3->t@6},{2->t@9,3->t@7,4->t@6}},ItemSize->{{1->3, 2->9, 3->1},
{1->6, 2->6, 3->2, 4->2}}] 

나란히

왼쪽에 출력; 오른쪽에 Piet Mondrian, 빨간색 파란색 노란색 컴포지션의 사진.


3
좋은 시도. 당신은 현상금을 쉽게 얻지 못합니다.
밀 마법사

11

루비, 112 (111) 자

피에트 몬드리안 (Piet Mondrian)

b="0 "*9
w="2 "*9
puts"P3 609 771 2",["1 0 0 "*267,w*8+b*2+w*79,w*89].map{|x|(x+b*3+w*42+b*3+w*66)*249}*(b*2436)

왼쪽에 내 작품, 오른쪽에 고급 참조.

여기에 이미지 설명을 입력하십시오

PPM의 최대 값을 조정하여 점수를 잃지 않고 색상을 1/9의 정밀도까지 약간 조정할 수 있습니다. "적합한 Win16 컬러"접근 방식을 선택했습니다. 8/9 흰색은 아마도 캔버스 원본 색상에 더 가깝지만 9/9는 저자의 의도에 더 가깝습니다.

우리가 대체 할 경우 하나 개의 문자를 저장할 수 있습니다 "1 0 0 "(w+b+b)(#의 F00 빨간색). 나는 그것이 "충분히 가깝다"고 생각합니다

파일 출력 버전 (골프 아님)

File.open "tmp.ppm", ?w do |f|
    b="0 "
    w="2 "
    s=b*27+w*378+b*27+w*594
    f.puts"P3 609 771 2",["1 0 0 "*267,w*72+b*18+w*711,w*801].map{|x|(x+s)*249}*(b*21924)
end

쉬운 것 : "0 "->b
Howard

@Howard 젠장. 축소하는 동안 이것을 놓쳤다. 감사합니다
존 드보락

그리고 일부는 더 많이 변경하는 경우 w="2 "w="2 "*9b도.
Howard

음 ... 나는 이것을 얻는다 (영원히 간다)
Doorknob

@Doorknob는 ppm파일 로 저장 하고 이미지 편집기에서 엽니 다
John Dvorak

9

SmileBASIC, 2774 1892 바이트

브로드 웨이 부기 우기

GCLS-920851D$="w$BȜąr:BȂąr7?Ƣǘy1SƑǘb<?ŵǘw-/ƶvyFMƮeb<<ŶIr:,ėǭy:Sėǘw-LŒƄw7;ėƎrkLćƄrBMĜey26ğ¸bKBē²y,Bć²w<Dđïw+DüïyDÒïw--çvyU8Òpw.1±syBM¨eb;<Iy28¥żrJNůbwN{ůr?@Ǣb3>Sǭw.Fb¤w24D­rMF5¤w,7Nnr[75ny1X=e
FOR I=1TO 36G A(),A(),A(),A(),A()NEXT
D$=" w*+r6,r1+b<*w1+b/+b++r(+w*+w,Br )b+*b()w0,w=+b,,r5+b1+r ,w24-Ȃ  w  w#.r-#-Ǥ  w*+r4,b3+r6*w2+b,-r-,b++r*+b**r(*b(*r*+b<-w@+b -w ,r4+b1+b%-w,5-ǔ  w +r)+w?#-ƹǘ w +r%-b,#-ƭ +w *r +w/,b2,r1-b;-w7+b*.w5+r1+r +-ƒ> w +r'-b*#-ž *r+)w +r?+b:+b1-b2+w:+w*+w3-b4-r4-b6,w2+r--w3+b1+r )w52-ş  w*+r )w ,b>+r7+b :w -b,+r:+w*+w7,r 6w ,r7-r0.w/+bM+b1+b ,w24-ľ *w +r)+r *w5+r9,b7.w++w ,r.+w*+w6*b Dw *r06w -r5+b *w8+w +r1+b ,w *r(7-ü  w*+w )b +w*+r*+bD-rC/r7+b*+r5+bD-r,.b/.w.+b *w8+r +w1+b'+r,4-Ò  w*+b )w+*r+*w +b )w<0wX-w +r*+b /wd-w/.b/*w+-r 7w)+bC+r,3-p *w+)w +b*+w*+b )w@2wU*w+*w++wx-wQ-w.,bT+b,.-* +w +r++r5,w6+w %|üŭ w3+r1*w(+r0+r7*b (w )r3*w+*w,+r-*w +b5+r )w6+w.,r1+w *b*-w +b *w(,r()w ,r+*r :| ȋ+w7*b 1w4)w +r %|şǷ+r,*w)+w.*w*)w ?r -w+'|pǷ)w,)w +b*#| Ƿ+r/+b()w ?r -w+*w),r(*w *b +w *r +| Ǣ w+(w +b1*w(+r0+b7)b *w *r2)w +b *w,+r7+b5+r )w6+b/+b )w1,r7+b.*b9*w +b*8| Ǎ w3+w )b0*w +r4)w +r/+w**w**b +w6+w )r1*b3+w /|üň+b-*w1+w%*r(-w +r *w.+w')r (w5*| ň w3+w )r0*w +b )r5*b/+w3+w *r +w *r,+w9+r3+w-*b (w +r,+b2,w /r3+b0)r *b+-w+*r :| ij w3+b )w)*r 'w +b (w+)w *r1+b0*w.+r6+b )w0)w,)w +b4+w +b0)w'*r1*b))w+*b.*b1(w+*r ;| 3w +b )w*)b 'w +b.)r 'w )b0+r <b,+b6+b.,b=+r 3w ,b +w *b 6w *r);b)+b7+b 1w=9| Z w3+r (w.-w +b1+w +r0+r )w +r (w,+r6+b *w),r8+b?+bJ*w:)w+)w.*r1)w+*r 7| >+r )w6+r2*b1+r6*b1*w +b*(| ,
FOR Q=1TO 27S=A()T=A()R=A()L=A()FOR I=1TO L
R A(),89R A(),A()NEXT
NEXT
DEF A()RETURN-32+ASC(POP(D$))END
DEF R L,C
IF L THEN IF R-13THEN G C,L,11,T,S:T=T+L ELSE G C,11,L,T,S:S=S+L
END
DEF G C,H,W,Y,X
GFILL X,Y,X+W-1,Y+H-1,-1716698*(C>88)-2302505*(C==87)-6080725*(C==82)-14597488*(C<67)END

스크린 샷

이미지의 각 "라인"은 다음 형식으로 저장됩니다.

x,y,direction,numberOfSegments,
yellowLength,nextColor,colorLength,
yellowLength,nextColor,colorLength,...

모든 숫자는로 저장되고 CHR$(number+32)색상은 한 문자로 저장됩니다. w, y, r, 또는 b한 방향으로 저장 |하거나-

추가 사각형은 다음과 같이 저장됩니다.

x,y,width,height,color,
x,y,width,height,color,...

같은 방법으로.


좋은! QBasic을 생각하고 있었지만 512x512 화면 모드는 없습니다.
DLosc

나는 매우 운이 좋았다. SmileBASIC의 그래픽 페이지는 정확히 512x512 픽셀입니다.
12Me21

7

SVG-455 480- 빨강, 파랑 및 노랑의 몬드리안 구성 II

SVG에 Javascript를 포함시키고 프로그래밍 언어 인 동적으로 만들 수 있다면. Ergo, 이것은 프로그램입니다. 는 IF 밝혀 x또는 yCOORD은 SVG에서 누락되어 0으로 디폴트 또한 red보다 짧은 #f00!

<?xml version="1.0" encoding="utf-8"?><svg xmlns="http://www.w3.org/2000/svg"><rect x="145" fill="red" width="455" height="440"/><rect y="432" fill="#00F" width="150" height="168"/><rect x="550" y="517" fill="#FF0" width="50" height="83"/><rect x="140" width="16" height="600"/><rect y="430" width="600" height="16"/><rect y="180" width="140" height="25"/><rect x="550" y="430" width="15" height="170"/><rect x="550" y="515" width="50" height="16"/></svg>

예쁜 인쇄 :

<?xml version="1.0" encoding="utf-8"?>
<svg xmlns="http://www.w3.org/2000/svg">
  <rect x="145" fill="red" width="455" height="440"/>
  <rect y="432" fill="#00F" width="150" height="168"/>
  <rect x="550" y="517" fill="#FF0" width="50" height="83"/>
  <rect x="140" width="16" height="600"/>
  <rect y="430" width="600" height="16"/>
  <rect y="180" width="140" height="25"/>
  <rect x="550" y="430" width="15" height="170"/>
  <rect x="550" y="515" width="50" height="16"/>
</svg>

대기, 내가 생각 레드 1935로 조성 B (No.II)는 2였다
존 드보락

4
@JanDvorak 모르겠다. 나는 Wikipedia에서 그를 찾았다. 솔직히 Piet는 게으른 화가였습니다. 그들은 모두 똑같이 보입니다.

큰 따옴표를 피하고 여전히 대부분의 브라우저에서 작동한다고 생각합니다. 그래도 준수에 대해 확실하지 않습니다.
존 드보락

@LegoStormtroopr 게으른? 그것은 짧은 프로그램 작성에 전념하는 웹 사이트에서 놀고있는 사람에게서 나온 것입니다.
boothby

1
@boothby Touche. 나는 초 미니멀리스트 접근법으로 인해 코드 골프에서 많은 것을 배웠다고 주장하려고했습니다. 그러나 ... Piet의 작업에 대해서도 마찬가지입니다.

3

SmileBASIC, 67 바이트

GCLS-1GFILL 353,0,367,#R,0GFILL.,121,#R,156,0GFILL 367,266,#R,293,0

나는 쉬운 것을 골랐다 : 흑백의 작곡 III

운 좋게도 SB의 그래픽 페이지는 정확히 512x512 픽셀이지만 400x240 화면에 모두 맞지 않으므로 스크린 샷을 쉽게 얻을 수 없습니다.

설명 :

GCLS -1 'fill screen with &HFFFFFFFF (white)
GFILL 353,0,367,511,0 'draw vertical line in &H00000000 (black)
GFILL 0,121,#R,156,0 'draw horizontal line
GFILL 367,266,#R,293,0 'draw small horizontal line

3

처리 중, 15,447 15,441 15,439 바이트

String i="";PImage x=loadImage(i);void draw(){image(x);}

무차별 대입으로 그리기 기능을 제거하는 방법을 찾지 못했습니다.

주 처리 엔진의 오류입니다 .b64가 너무 커서 생각합니다. 여기서 테스트 할 수 있습니다 .

JS 바이올린은 그것을 100 * 100px로 자릅니다. 내 base64는 작동하지만 온라인 환경은 작동하지 않습니다. :(


당신은 사용하여이 골프를 할 수있는 PImage x=loadImage(i);대신에
Kritixi LITHOS을

1
이 질문에는 512x512 이상의 해상도가 필요하지만 바이올린의 캔버스는 100x100입니다. 이것은 JSFiddle의 기발한가요?
Dennis

@Dennis 캔버스 크기 만이 아닙니다. 이미지가 오른쪽과 아래쪽에서 잘려서 결과가 잘못됩니다.
mbomb007

@ 데니스 예, 그렇습니다. 512 * 512px로 수동 설정하면 여전히 같은 크기로 자릅니다. 그것은 단지 JS 바이올린이며, 내가 사용한 b64는 512보다 큽니다.
Rɪᴋᴇʀ

data:;base64마찬가지로 작동
Kritixi Lithos

2

Love2D, 4956 + 395 + 1 = 5351 바이트

f=io.open("d","rb")s=f:read("*a"):gsub("(.)(.)",function(a,b)return a:rep(b:byte())end)o=love.image.newImageData(512,512)c={{244,243,248},{173,24,0},{250,209,5},{30,64,164}}o:mapPixel(function(x,y)i=math.floor((x+math.floor(y/4)*512)/4)O=3-i%4 n=s:sub(math.floor(i/4)+1,math.floor(i/4)+1)if n and#n>0 then b=math.floor(n:byte()/(4^O))%4 else b=0 end return unpack(c[b+1])end)o:encode("png","o") 

데이터 파일은 여기 에 저장됩니다

산출:

산출

기발한:

기발한

설명

f = io.open("d","rb")                                                   -- Open the image in raw format.
s = f:read("*a"):gsub("(.)(.)",function(a,b)return a:rep(b:byte())end)  -- And read it's contents. 
o=love.image.newImageData(512,512)                                      -- Make the output image
c = {{244,243,248},{173,24,0},{250,209,5},{30,64,164}}                  -- Build the Pallet
o:mapPixel(function(x,y)                                                -- Fill the image, based on a function
    i = (x+y*512)                                   -- The position this pixel exists on the string, 0 indexed.
    O = 3-i%4                                       -- The offset. The byte stores 4 pixels, so this is the id among a group of 4.
    n = s:sub(math.floor(i/4)+1,math.floor(i/4)+1)  -- And this gets the byte itself.
    if n and #n > 0 then                            -- Sometimes this is null and I don't like it.
        b = math.floor(n:byte()/(4^O))%4            -- /4^offset % 4 gives us the value of the index on the pallet.
    else
        b = 0                                       -- Fallback plan.
    end
    return unpack(c[b+1])                           -- Set the pixel to the colour required.
end)
o:encode("png","o") -- Store it in Appdata as "o", which is a png file.

인코더.

이것은 이미지를 인코딩하는 데 사용한 스크립트입니다. GIF는 좀 더 압축되었지만 GIF를 표시하는 데 어려움이 없었습니다.

img = love.image.newImageData("mondrian.jpg")
-- white    0
-- blue     3
-- yellow   2
-- red      1

cols = {{244,243,248},{173,24,0},{250,209,5},{30,64,164}}

local s = ""
for y = 0, 511 do
    for x = 0, 511 do
        local r,g,b = img:getPixel(x,y)
        local n = 0
        local D = math.huge
        for k,v in pairs(cols) do
            local d = (v[1]-r)^2 + (v[2]-g)^2 + (v[3]-b)^2
            if d < D then
                n = k-1
                D = d
            end
        end
        s = s .. n
    end
end
-- Convert base 4 to base 256
-- How many digits do we need- Every 4 digits
encd = ""
for str in s:gmatch"...." do
    local n = str:sub(1,1) * 4^3 +
              str:sub(2,2) * 4^2 +
              str:sub(3,3) * 4^1 +
              str:sub(4,4) * 4^0
    encd = encd .. string.char(n)
end

f = io.open("stored.dat","wb")

smlr = ""
lst = ""
c = 0
for s in encd:gmatch"." do
    if s == lst then
        c = c + 1
        while c > 255 do
            smlr = smlr .. lst .. string.char(255)
            c = c - 255
        end
    else
        if c > 0 then
            smlr = smlr .. lst .. string.char(c)
        end
        lst = s
        c = 1
    end
end

f:write(smlr)

현상금을 위해 주로 경쟁합니다. 더 좋은 방법이있을 수 있지만 간단한 팔레트와 실행 길이 디코딩을 사용하는 것이 흥미로울 것이라고 생각했습니다.

편집 : 입력 이미지가 단순화되었지만 약간 덜 정확하지만 바이트는 줄었습니다.


2
출력 부분이 퍼즐 조각으로 만들어진 것처럼 보이는 이유는 무엇입니까? "약간 덜 정확하지만 바이트는 더 작습니다"라는 의미입니까? 컬러 스트립의 결과 틈새로 인해 이것이 유효한 레크리에이션이 아닌 것 같습니다.
DLosc
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.