Килим аеропорту


17

У 2015 році міжнародний аеропорт Портленда розпочав заміну їх знакового килима . Я хочу, щоб ви написали програму, щоб намалювати їх старий килим якомога менше байтів.

Килим:

Одна плитка

Технічні умови

  • Ось посилання на масштабоване зображення у форматі PDF однієї плитки. Вихід повинен відповідати відносним розмірам і розміщенню цього зображення.

  • Усі кольори у вашому кінцевому зображенні повинні бути в межах 15 від кожного значення RGB у зазначеному зображенні. Вони перераховані нижче для вашої зручності.

                Red   Green Blue
    Teal:       0,    168,  142
    Magenta:    168,  108,  185
    Orange:     247,  58,   58
    Light Blue: 90,   166,  216
    Dark Blue:  0,    77,   117
    
  • Вихід повинен бути не менше 150х150 пікселів і повинен бути квадратним. Якщо ви вирішили виводити в масштабованому форматі, як векторне зображення, вам слід точно відповідати зображенню.

  • Ви можете виводити зображення в будь-якому попередньому форматі зображення.

  • Це тому ви повинні прагнути мінімізувати кількість байтів у своєму коді.



@Hexaholic Я не думаю, тому я потрапляв випадково у вікіпедію, і я потрапляв на сторінку. Однак я, можливо, також бачив це на reddit перед рукою.
Post Rock Garf Hunter

1
Це повинно бути двовимірне зображення чи це могло бути щось на зразок моделі, розглянутої з певного кута?
devRicher

Відповіді:


9

Чистий HTML, 873 байти

<table width=152 height=152 bgcolor=#0a8><tr><td colspan=7><td bgcolor=#5AD><tr><td><td bgcolor=#057><td colspan=5><td bgcolor=#5AD><tr><td><td><td bgcolor=#057><td colspan=4><td bgcolor=#5AD><tr><td><td><td><td bgcolor=#057><td><td><td><td bgcolor=#5AD><tr><td colspan=7><td bgcolor=#057><td><td><td bgcolor=#057><tr><td colspan=7><td bgcolor=#057><td><td bgcolor=#057><tr><td colspan=7><td bgcolor=#057><td bgcolor=#057><td><td><td><td bgcolor=#F33><td bgcolor=#F33><td bgcolor=#F33><tr><td colspan=6><td bgcolor=#F33><td bgcolor=#057><td colspan=7 bgcolor=#057><tr><td bgcolor=#A6B><td bgcolor=#A6B><td bgcolor=#A6B><td bgcolor=#A6B><td bgcolor=#A6B><td bgcolor=#A6B><td bgcolor=#A6B><td rowspan=6 bgcolor=#057><tr><td><tr><td><tr><td colspan=11><td bgcolor=#057><tr><td colspan=12><td bgcolor=#057><tr><td colspan=13><td bgcolor=#057><tr><td colspan=7><td bgcolor=#057>

HTML + CSS, 625 байт

#l{background:#5AD}th{background:#057}#o{background:#F33}#m>td{background:#A6B
<table width=152 height=152 bgcolor=#0A8><tr><td colspan=7><td id=l><tr><td><th><td colspan=5><td id=l><tr><td><td><th><td colspan=4><td id=l><tr><td><td><td><th><td><td><td><td id=l><tr><td colspan=7><th><td><td><th><tr><td colspan=7><th><td><th><tr><td colspan=7><th><th><td><td><td><td bgcolor=#F33><td bgcolor=#F33><td bgcolor=#F33><tr><td colspan=6><td bgcolor=#F33><th><th colspan=7><tr id=m><td><td><td><td><td><td><td><th rowspan=6><tr><td><tr><td><tr><td colspan=11><th><tr><td colspan=12><th><tr><td colspan=13><th><tr><td colspan=7><th>


9

Тікз, 725 693 681 671 байт

\documentclass{standalone}\usepackage{xcolor,tikz}\begin{document}\tikz[line width=20,every node/.style={minimum size=20}]{\definecolor{t}{RGB}{0,168,142}\definecolor{m}{RGB}{168,99,185}\definecolor{o}{RGB}{247,58,58}\definecolor{b}{RGB}{90,166,216}\definecolor{d}{RGB}{40,77,117}\fill[t](-7.5,-7.5)rectangle(7.5,7.5);\draw(-1,0)node[fill=o]{};\foreach\x in{1,...,7}{\draw(-\x,-1)node[fill=m]{};\draw(0,\x)node[fill=b]{};}\foreach\x in{1,...,3}{\draw(\x,\x)node[fill=d]{};\draw(3+\x,-3-\x)node[fill=d]{};\draw(-3-\x,3+\x)node[fill=d]{};\draw(4+\x,1)node[fill=o]{};}\draw[d](.65,0)--(7.35,0);\draw[d,dash pattern=on20off8.5on162.5off8.5](0,-7.35)--(0,3.35);}\end{document}

Спробуйте в Інтернеті!

Пояснення

Значна частина коду - обгортка:

\documentclass{standalone}\usepackage{xcolor,tikz}\begin{document}\tikz{...}\end{document}

Це невелика відмінність для звичайної обгортки Tikz в тому, що вона також має лінію \usepackage{xcolor} щоб ми могли правильно створювати кольори.

Перше, що робиться - це line width=20,every node/.style={minimum size=20}] це встановлювати лінії та вузли відповідного розміру.

Після цього ми визначаємо кольори, які ми будемо використовувати для різних частин зображення:

\definecolor{t}{RGB}{0,168,142}\definecolor{m}{RGB}{168,99,185}\definecolor{o}{RGB}{247,58,58}\definecolor{b}{RGB}{90,166,216}\definecolor{d}{RGB}{40,77,117}

Тепер, коли все налаштовано, ми малюємо фон для нашого полотна:

\fill[t](-7.5,-7.5)rectangle(7.5,7.5);

(Я не буду включати зображення цього, тому що це просто слізний квадрат, але я буду включати зображення кожного іншого кроку)

Перший вузол, який ми додаємо, - це помаранчевий вузол, що знаходиться ліворуч від центру полотна.

\draw(-1,0)node[fill=o]{};

Апельсин у морі

Тепер ми намалюємо світло-сині та пурпурові вузли. Є 7 синіх вузлів і 4 синіх вузла, але ми можемо намалювати додаткові вузли, які згодом будуть висвітлюватися рядками, тому ми намалюємо 7 кожного.

\foreach\x in{1,...,7}{
    \draw(-\x,-1)node[fill=m]{};
    \draw(0,\x)node[fill=b]{};
}

Роздвоєні доріжки

Тепер ми намалюємо всі групи по 3 крапки за допомогою однієї \foreachпетлі

\foreach\x in{1,...,3}{\draw(\x,\x)node[fill=d]{};\draw(3+\x,-3-\x)node[fill=d]{};\draw(-3-\x,3+\x)node[fill=d]{};\draw(4+\x,1)node[fill=o]{};}

Розсипані точки

Тепер проведемо правильну лінію. Ця лінія буде простою лінією із зміщеннями .35в кожному напрямку, щоб відповідати розміру вузла.

\draw[d](.65,0)--(7.35,0);

Зіткнення

Тепер ми повинні намалювати темно-сині лінії та квадрати на осі x. Ми намалюємо їх однією лінією за допомогою спеціального малюнка тире.

Цей візерунок: [dash pattern=on20off8.5on162.5off8.5]Це створює квадрат з довгим суцільним хвостом. Наш рядок розпочнеться знизу і не буде повністю охоплювати 2 цикли візерунка.

\draw[d,dash pattern=on20off8.5on162.5off8.5](0,-7.35)--(0,3.35);

Фінал

І ось ми закінчили.


Чи можете ви використовувати цифри для представлення кольорів RGB у Tikz, а не вводити компенсації RGB?
Yytsi

@TuukkaX Я думаю, що так, але я не міг цього зрозуміти. Якщо ви знаєте, як я був би вдячний просвітленню.
Пост Рок Гарф Хантер

Я взагалі не знаю Тікза, тому не можу допомогти з цим :( Однак, якщо я зрозумів ваше правило про "в межах 15 кожного RGB" право, ви можете змінити 108 на 99, оскільки помилка становить менше 15.
Yytsi

@TuukkaX Дякую!
Post Rock Garf Hunter

Використання \definecolorіз HTMLспецифікацією (а не RGB) дозволяє задавати кольори за допомогою шістнадцяткових.
Джуліан Вольф

6

буквальний файл PNG, 283 , 234 227 байт

EDIT : Використовуючи онлайн-сервіс стиснення зображень https://compress-or-die.com/ , це зменшилось ще на 7 байт.

albn @ alexhi

j:~/tmp$ ls -l carpet3.png
-rw-r--r-- 1 albn albn 227 15. Feb 12:01 carpet3.png
albn@alexhij:~/tmp$ base64 carpet3.png 
iVBORw0KGgoAAAANSUhEUgAAAJgAAACYBAMAAADq7D0SAAAAD1BMVEUAqI4ATXWobLn3Ojpapthl
S7nNAAAAj0lEQVR4Ae3ThRHCQBQGYVqgBVq4Fui/Jt4ILks8/80uLvkyOTlkd67EILHojtWEyxQT
Sw6uFS5TTCw/uFa+TDGx/PjS3z+KiS2GcRtgzIqJdboDPomteniCxMTyatXtMiExMcB22amCJ7wG
MbHpBWBiYmJiYmJwAjGx/ncAn0VMrP8dwL+KieXHFyImltoF6oWZiblRTNQAAAAASUVORK5CYII=

carpet3.png

227 байт - це фактичний розмір двійкового файлу carpet.png. Якщо закодовано в base64, як відображено в цитованому блоці вище, воно на кілька байт довше (308 байт). Інкапсулюючи, що в фрагмент html, який надає зображення прямо, додасть ще кілька байтів:

HTML, 414 , 343 , 336 байт

<img src=

Редагувати : я видалив лапки та закриття> як запропонував Шаггі. Також стиснули зображення вниз ще на 17 , 24 байти


1
Я не думаю, що буквальний файл тут вважається дійсною мовою програмування на коді-гольф. Це залежить від ОП, чи це дійсно чи ні.
Товариш SparklePony

1
Ви можете мати рацію, але навіть опис тегу kolmogorov-складності на codegolf.stackexchange.com/tags/kolmogorov-complexity/info згадує про складний рядок, найкоротшим поданням якого може бути друк його буквально. Якщо буквальний рядок вважається "найгіршим рішенням" для коду-гольфу на основі рядків, файл прямого зображення може вважатися "гіршим рішенням" для коду-гольфу на основі зображень. Редагувати: я розмістив лише файл, тому що мене здивувало, що він насправді коротший, ніж інші рішення, розміщені раніше. (після вилучення необов’язкового фрагмента часу з файлу)
неділя,

Якщо це залежить від мене, я з цим добре.
Пост Рок-Гарф Мисливець

2
Трохи стиснувшись, ви могли це знизити. Крім того, киньте лапки, будь-який проміжок =та закриття >. Ось 366-байтна версія, над якою я працював, перш ніж побачив вашу відповідь:<img src=
Shaggy

1
@ComradeSparklePony Зазвичай нам не потрібні відповіді мови програмування на такі питання: codegolf.meta.stackexchange.com/questions/3610/…
isaacg

5

Математика, 285 байт

e={1,1};r=RGBColor["#"<>#]&;c=Cuboid;s=c[3#-e,3#+e]&;a=Array;b=a[s[{1,-1}#]&,3,#]&;Graphics@{r@"0a8",c[-23e,23e],r@"a6b",a[s@{-#,-1}&,7],r@"f33",a[s@{#,1}&,3,5],s@{-1,0},r@"5ad",a[s@{0,#}&,4,4],r@"057",a[s[e#]&,4,0],b@4,b[-6],s@{0,-7},{-1,2}~c~{1,10},{-1,-2}~c~{1,-19},{2,-1}~c~{22,1}}

Легше читати:

 1  c = Cuboid; e = {1, 1};
 2  s = c[3 # - e, 3 # + e] &;
 3  a = Array; b = a[s[{1, -1} #] &, 3, #] &;
 4  r = RGBColor["#" <> #] &; 
 5  Graphics@{
 6   r@"0a8", c[-23 e, 23 e],
 7   r@"a6b", a[s@{-#, -1} &, 7],
 8   r@"f33", a[s@{#, 1} &, 3, 5], s@{-1, 0},
 9   r@"5ad", a[s@{0, #} &, 4, 4],
10   r@"057",
11    a[s[e #] &, 4, 0], b@4, b[-6], s@{0, -7},
12    {-1, 2}~c~{1, 10}, {-1, -2}~c~{1, -19}, {2, -1}~c~{22, 1}
13  }

Рядки 1–3 визначають короткі назви функцій, найважливішим з яких є sмалювання квадрата, по центру в отриманих ним координатах (дійсно в 3 рази більше його координат, для відповідного масштабування). Рядок 4 визначає кольорову функцію за допомогою системи RGB "ярлик" Mathematica:, RGBColor["#xyz"]де xyzзнаходяться шістнадцяткові цифриRGBColor[{17x, 17y, 17z}] (так, щоб кожна координата мала 16 однаково розташованих варіантів, що працює від 0 до 255). Перші команди в рядках 6–10 перемикають поточний колір, використовуючи ярлики, найближчі до визначених п'яти кольорів (жодне значення не вимикається більш ніж на 8, коли ми округляємо до найближчого кратного 17).

Лінія 6 малює великий квадрат чирок. Рядок 7 малює лінію пурпурних квадратів, лінія 8 малює лінію помаранчевих квадратів та одинарного помаранчевого квадрата. Лінія 9 малює лінію світло-синіх квадратів. Рядок 11 малює три діагональні лінії темно-синіх квадратів, а також єдиний темно-синій квадрат внизу. Нарешті, рядок 12 малює три довгі темно-сині прямокутники. Вихід нижче:

Портленд

(Гольф-наконечник: команда Cuboid, призначена для 3D-графічних об'єктів, працює чудово на 2d і коротша, ніж Rectangle.)


2

Пітона, 420

from PIL import Image,ImageDraw
B=0,77,117
I=Image.new('RGB',(300,300),(0,168,142))
r=ImageDraw.Draw(I).rectangle
for x,y,c in['7172737a98cde670123456bcd70112233456666778888888bcde23232323331111300000003333'[x::26]for x in range(26)]:exec'r([W,W,14+W,14+W],[(168,108,185),(247,58,58),(90,166,216),B][%s]);'.replace('W','2+20*0x%s')%(x,y,x,y,c)
r([162,142,296,156],B)
r([142,82,156,136],B)
r([142,162,156,276],B)
I.show()

1

HTML / SVG, 550 542 521 байт

<svg><path fill=#0a8 d="M0 0h152v152H0z"/><path fill=#5ad d="M72 2h8v8h-8zm0 10h8v8h-8zm0 10h8v8h-8zm0 10h8v8h-8z"/><path fill=#057 d="M12 12h8v8h-8zm10 10h8v8h-8zm10 10h8v8h-8zm40 10h8v28h-8zm0 30h8v8h-8zm10-10h8v8h-8zm10-10h8v8h-8zm10-10h8v8h-8zM82 72h68v8H82zM72 82h8v58h-8zm0 60h8v8h-8zm40-30h8v8h-8zm10 10h8v8h-8zm10 10h8v8h-8z"/><path fill=#f33 d="M62 72h8v8h-8zm60-10h8v8h-8zm10 0h8v8h-8zm10 0h8v8h-8z"/><path fill=#a6b d="M2 82h8v8H2zm10 0h8v8h-8zm10 0h8v8h-8zm10 0h8v8h-8zm10 0h8v8h-8zm10 0h8v8h-8zm10 0h8v8h-8z"


1

HTML, 366 байт

Неділя отримав Base64 відповідь , поки я все ще працюю над цим; якщо він / він вирішить його використовувати, я видалю цю відповідь.

<img src=

Якщо власний рядок Base64 є правильною відповіддю, то це лише 335 байт:

iVBORw0KGgoAAAANSUhEUgAAAJgAAACYBAMAAADq7D0SAAAAD1BMVEUAqI4ATXWobLlaptj3OjrqGXAuAAAAp0lEQVRo3u3YQQqFMAxFUbeQLbiFbsH9r8k3y8CmTiKm7b2Dwv/CgUAD4jF3TYGBRdgKmRqPCQa28gaMZ20KDGz5DQhnbQoMTG2wAcPR/ScY2HeYVw4zBQYWYDUvbRLWFS/lBxhYhM3bpXzMcWBgEVa5U70cpsDAnkf1FxcwMDAwMLBczP8DAwuwmpc2HzMFBhY8qHlp8zFTYGCdyn8GKrhOYBtjv3QDvf+Zic+8bOsAAAAASUVORK5CYII

1

HTML / SVG + JavaScript (ES6), 500 499 байт

Для >того, щоб він функціонував як фрагмент, потрібна додаткова інформація. Дійсний код див. У цій скрипці .

[[t="5ad",2],[t,o=12],[t,p=22],[t,q=32],[,o,o],[,p,p],[,q,q],[,42,,28],[],[,v=62,s=82],[,52,92],[,42,102],[,,s,,68],[,s,,58],[,142],[,112,112],[,122,122],[,132,132],[t="f33",,v],[t,v,122],[t,v,132],[t,v,142],[t="a6b",s,2],[t,s,o],[t,s,p],[t,s,q],[t,s,42],[t,s,52],[t,s,v],["0a8",0,0,152,152]].map(x=>a(x[0],x[1],x[2],x[3],x[4]),a=(f="057",y=72,x=72,h=8,w=8)=>(c.after(r=c.cloneNode()),r.id++,r[s="setAttribute"]("fill","#"+f),r[s]("x",x),r[s]("y",y),r[s]("width",w),r[s]("height",h)))
<svg><rect id=c>


Пояснення

Масив масивів зіставляється функції a, створюючи клони rectв HTML, вставляючи їх після початкового rectі установки їх fill, x, y, width& heightатрибути. Кожен масив містить значення для цих атрибутів у тому порядку, при цьому будь-які відсутні значення встановлюються за замовчуванням параметрів a. На перший погляд, непотрібне r.id++дозволяє використовувати cloneNode()при цьому, гарантуючи, що існує завжди 1 rectз idc; це економить необхідність використання смішно дорогого document.createElementNS("http://www.w3.org/2000/svg","rect").


1

PHP + SVG, 425 байт

<svg><rect x=0 y=0 fill=#00a88e width=150 height=150 /><?foreach(["004d75"=>[[1,1],[2,2],[3,3],[7,14],[7,7],[8,6],[9,5],[10,4],[11,11],[12,12],[13,13],[7,4,0,2],[8,7,6,0],[7,8,0,5]],"5aa6d8"=>[[7,0],[7,1],[7,2],[7,3]],a86cb9=>[[0,8],[1,8],[2,8],[3,8],[4,8],[5,8],[6,8]],f73a3a=>[[6,7],[12,6],[13,6],[14,6]]]as$c=>$p)foreach($p as$v)echo"<rect x={$v[0]}1 y={$v[1]}1 width=".(8+10*$v[2])." height=".(8+10*$v[3])." fill=#$c />";

розширений

<svg><rect x=0 y=0 fill=#00a88e width=150 height=150 />
<?foreach([
"004d75"=>[[1,1],[2,2],[3,3],[7,14],[7,7],[8,6],[9,5],[10,4],[11,11],[12,12],[13,13],[7,4,0,2],[8,7,6,0],[7,8,0,5]]
,"5aa6d8"=>[[7,0],[7,1],[7,2],[7,3]]
,a86cb9=>[[0,8],[1,8],[2,8],[3,8],[4,8],[5,8],[6,8]]
,f73a3a=>[[6,7],[12,6],[13,6],[14,6]] # Array containing color and position ,width, height of each rect without the background
]as$c=>$p)
  foreach($p as$v)
    echo"<rect x={$v[0]}1 y={$v[1]}1 width=".(8+10*$v[2])." height=".(8+10*$v[3])." fill=#$c />"; # Output the rects

Результат коду у фрагменті HTML

<svg><rect x=0 y=0 fill=#00a88e width=150 height=150 /><rect x=11 y=11 width=8 height=8 fill=#004d75 /><rect x=21 y=21 width=8 height=8 fill=#004d75 /><rect x=31 y=31 width=8 height=8 fill=#004d75 /><rect x=71 y=141 width=8 height=8 fill=#004d75 /><rect x=71 y=71 width=8 height=8 fill=#004d75 /><rect x=81 y=61 width=8 height=8 fill=#004d75 /><rect x=91 y=51 width=8 height=8 fill=#004d75 /><rect x=101 y=41 width=8 height=8 fill=#004d75 /><rect x=111 y=111 width=8 height=8 fill=#004d75 /><rect x=121 y=121 width=8 height=8 fill=#004d75 /><rect x=131 y=131 width=8 height=8 fill=#004d75 /><rect x=71 y=41 width=8 height=28 fill=#004d75 /><rect x=81 y=71 width=68 height=8 fill=#004d75 /><rect x=71 y=81 width=8 height=58 fill=#004d75 /><rect x=71 y=01 width=8 height=8 fill=#5aa6d8 /><rect x=71 y=11 width=8 height=8 fill=#5aa6d8 /><rect x=71 y=21 width=8 height=8 fill=#5aa6d8 /><rect x=71 y=31 width=8 height=8 fill=#5aa6d8 /><rect x=01 y=81 width=8 height=8 fill=#a86cb9 /><rect x=11 y=81 width=8 height=8 fill=#a86cb9 /><rect x=21 y=81 width=8 height=8 fill=#a86cb9 /><rect x=31 y=81 width=8 height=8 fill=#a86cb9 /><rect x=41 y=81 width=8 height=8 fill=#a86cb9 /><rect x=51 y=81 width=8 height=8 fill=#a86cb9 /><rect x=61 y=81 width=8 height=8 fill=#a86cb9 /><rect x=61 y=71 width=8 height=8 fill=#f73a3a /><rect x=121 y=61 width=8 height=8 fill=#f73a3a /><rect x=131 y=61 width=8 height=8 fill=#f73a3a /><rect x=141 y=61 width=8 height=8 fill=#f73a3a />

PHP + SVG, 375 байт

Цей кількість байтів можна досягти, стиснувши SVG

<?=bzdecompress(base64_decode("QlpoNDFBWSZTWY2177gAASSZgEgA/+c/5B3gMAE5TQVtQeig0AAACU0VNMAAAEYIlEnpMKNlGahso2plh0zoaSEpIkukINaC3RWRF74IvArdRF1FcBXrSTFWXTorp2xvpb3k7FbaV62syISgiBEweHhxtWUmgWCsqqaKSEARyAOAEZJJOwYBQqTAWotSrmEXJbBRTYNhCg4RPaKOUUbAX+Fr4VfIrzzIQQkkJCWfMEEOOISTuDkOzgQzDQDNQKu/4K7AZh8L41DddV8iv2LQOBXv+iugriHAr6sK/IrUV1FeRXMV3FdhW8V9KugrmK8CvOQin+LuSKcKEhG2vfcA"));
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.