ค้นหาชื่อสี HTML ที่ใกล้เคียงที่สุด


13

อินพุต

ฐานสิบหกเดียวรหัสสี 6 #หลักอักษรตัวใหญ่โดยไม่ต้อง สามารถเป็นจำนวนเต็ม 24 บิตหากคุณต้องการ

เอาท์พุต

ชื่อสี HTML ที่ใกล้เคียงที่สุด(เช่นredหรือdark-salmonตามที่กำหนดเป็นhttps://www.w3schools.com/colors/colors_names.aspหรือดูด้านล่าง) ระยะทางถูกกำหนดโดยการรวมความแตกต่างในช่องสีแดงสีเขียวและสีน้ำเงิน

ตัวอย่าง

FF04FE: magenta

FFFFFF: white

457CCB(ครึ่งทางระหว่างsteelblueและdarkslateblue): steelblue(ปัดเศษขึ้น )

กฎระเบียบ

  • ช่องโหว่มาตรฐานใช้
  • ใช้ I / O มาตรฐาน
  • ปัดเศษขึ้นเป็นสีด้วยผลรวมของช่องที่สูงขึ้นหากครึ่งทางระหว่างสองสี หากสองสีมีผลรวมของช่องเหมือนกันให้ส่งออกสีที่สูงกว่าเป็นรหัสฐานสิบหก: เช่น red= #FF0000= 16711680> blue= #0000FF= 256
  • หากรหัสฐานสิบหกมีสองชื่อ (เช่นgreyและgray) ให้ส่งออกอย่างใดอย่างหนึ่ง
  • ผลลัพธ์สามารถเป็นตัวพิมพ์ใหญ่และใช้เครื่องหมายขีดคั่นตามที่คุณต้องการ
  • การเว้นวรรค / ก่อนหน้า / การขึ้นบรรทัดใหม่นั้นใช้ได้
  • คุณต้องแสดงผลชื่อเต็ม
  • นี่คือดังนั้นคำตอบที่สั้นที่สุดในหน่วยไบต์ชนะ

สี

ตามคำแนะนำในความคิดเห็นต่อไปนี้เป็นชื่อสีทั้งหมดที่มีค่าเลขฐานสิบหกที่เกี่ยวข้องในรูปแบบ CSV:

Color Name,HEX
Black,#000000
Navy,#000080
DarkBlue,#00008B
MediumBlue,#0000CD
Blue,#0000FF
DarkGreen,#006400
Green,#008000
Teal,#008080
DarkCyan,#008B8B
DeepSkyBlue,#00BFFF
DarkTurquoise,#00CED1
MediumSpringGreen,#00FA9A
Lime,#00FF00
SpringGreen,#00FF7F
Aqua,#00FFFF
Cyan,#00FFFF
MidnightBlue,#191970
DodgerBlue,#1E90FF
LightSeaGreen,#20B2AA
ForestGreen,#228B22
SeaGreen,#2E8B57
DarkSlateGray,#2F4F4F
DarkSlateGrey,#2F4F4F
LimeGreen,#32CD32
MediumSeaGreen,#3CB371
Turquoise,#40E0D0
RoyalBlue,#4169E1
SteelBlue,#4682B4
DarkSlateBlue,#483D8B
MediumTurquoise,#48D1CC
Indigo,#4B0082
DarkOliveGreen,#556B2F
CadetBlue,#5F9EA0
CornflowerBlue,#6495ED
RebeccaPurple,#663399
MediumAquaMarine,#66CDAA
DimGray,#696969
DimGrey,#696969
SlateBlue,#6A5ACD
OliveDrab,#6B8E23
SlateGray,#708090
SlateGrey,#708090
LightSlateGray,#778899
LightSlateGrey,#778899
MediumSlateBlue,#7B68EE
LawnGreen,#7CFC00
Chartreuse,#7FFF00
Aquamarine,#7FFFD4
Maroon,#800000
Purple,#800080
Olive,#808000
Gray,#808080
Grey,#808080
SkyBlue,#87CEEB
LightSkyBlue,#87CEFA
BlueViolet,#8A2BE2
DarkRed,#8B0000
DarkMagenta,#8B008B
SaddleBrown,#8B4513
DarkSeaGreen,#8FBC8F
LightGreen,#90EE90
MediumPurple,#9370DB
DarkViolet,#9400D3
PaleGreen,#98FB98
DarkOrchid,#9932CC
YellowGreen,#9ACD32
Sienna,#A0522D
Brown,#A52A2A
DarkGray,#A9A9A9
DarkGrey,#A9A9A9
LightBlue,#ADD8E6
GreenYellow,#ADFF2F
PaleTurquoise,#AFEEEE
LightSteelBlue,#B0C4DE
PowderBlue,#B0E0E6
FireBrick,#B22222
DarkGoldenRod,#B8860B
MediumOrchid,#BA55D3
RosyBrown,#BC8F8F
DarkKhaki,#BDB76B
Silver,#C0C0C0
MediumVioletRed,#C71585
IndianRed,#CD5C5C
Peru,#CD853F
Chocolate,#D2691E
Tan,#D2B48C
LightGray,#D3D3D3
LightGrey,#D3D3D3
Thistle,#D8BFD8
Orchid,#DA70D6
GoldenRod,#DAA520
PaleVioletRed,#DB7093
Crimson,#DC143C
Gainsboro,#DCDCDC
Plum,#DDA0DD
BurlyWood,#DEB887
LightCyan,#E0FFFF
Lavender,#E6E6FA
DarkSalmon,#E9967A
Violet,#EE82EE
PaleGoldenRod,#EEE8AA
LightCoral,#F08080
Khaki,#F0E68C
AliceBlue,#F0F8FF
HoneyDew,#F0FFF0
Azure,#F0FFFF
SandyBrown,#F4A460
Wheat,#F5DEB3
Beige,#F5F5DC
WhiteSmoke,#F5F5F5
MintCream,#F5FFFA
GhostWhite,#F8F8FF
Salmon,#FA8072
AntiqueWhite,#FAEBD7
Linen,#FAF0E6
LightGoldenRodYellow,#FAFAD2
OldLace,#FDF5E6
Red,#FF0000
Fuchsia,#FF00FF
Magenta,#FF00FF
DeepPink,#FF1493
OrangeRed,#FF4500
Tomato,#FF6347
HotPink,#FF69B4
Coral,#FF7F50
DarkOrange,#FF8C00
LightSalmon,#FFA07A
Orange,#FFA500
LightPink,#FFB6C1
Pink,#FFC0CB
Gold,#FFD700
PeachPuff,#FFDAB9
NavajoWhite,#FFDEAD
Moccasin,#FFE4B5
Bisque,#FFE4C4
MistyRose,#FFE4E1
BlanchedAlmond,#FFEBCD
PapayaWhip,#FFEFD5
LavenderBlush,#FFF0F5
SeaShell,#FFF5EE
Cornsilk,#FFF8DC
LemonChiffon,#FFFACD
FloralWhite,#FFFAF0
Snow,#FFFAFA
Yellow,#FFFF00
LightYellow,#FFFFE0
Ivory,#FFFFF0
White,#FFFFFF

1
ที่เกี่ยวข้อง (โดยทั่วไปแล้วเป็นงานตรงกันข้าม)
Arnauld

2
Turquoise (# 40E0D0) ไม่ใช่สีใกล้เคียงกับ # 40FFEA ด้วยผลรวมของความแตกต่างหรือไม่ (vsสำหรับ Aqua และ Aquamarine)855785
Arnauld

1
ไม่ควรปัดเศษขึ้นเป็นเหล็กกล้าเป็นสีน้ำเงินแทนที่จะเป็นสีน้ำเงินเข้ม?
TSH

Aqua/Cyan; DarkSlateGray/DarkSlateGrey; DimGray/DimGrey; SlateGray/SlateGrey; LightSlateGray/LightSlateGrey; Gray/Grey; DarkGray/DarkGrey; LightGray/LightGrey; Fuchsia/Magentaสำหรับคนอื่นทำกับความท้าทายนี้ที่นี่เป็นสีซ้ำคุณสามารถเลือกหนึ่งของ: ฉันกรองออกเพียงสีเทาที่ซ้ำกัน แต่ไม่ใช่อีกสองสี ดังนั้นฉันจึงได้รับข้อผิดพลาดจากการตั้งค่าที่ไม่ตรงกันในรายการสตริงและจำนวนเต็มของฉัน .. >.> คิดว่าฉันจะโพสต์สิ่งนี้ที่นี่เพื่อป้องกันไม่ให้ผู้อื่นทำผิดพลาดแบบเดียวกันกับที่ฉันทำ
Kevin Cruijssen

คำตอบ:


17

C # (Visual C # Interactive Compiler) , 231 + 21 = 252 ไบต์

s=>Color.FromArgb(Convert.ToInt32(s,16));f=s=>Enum.GetNames(typeof(KnownColor)).Select(x=>Color.FromName(x)).Where(x=>!x.IsSystemColor&x.A>254).OrderBy(x=>Math.Abs(x.R-C(s).R)+Math.Abs(x.G-C(s).G)+Math.Abs(x.B-C(s).B)).First().Name

คำอธิบาย:

using System.Drawing; //System library that handles Colors in C#

C=s=>Color.FromArgb(Convert.ToInt32(s,16));        //helper method. receives a hex string and returns it's Color

f=s=>Enum.GetNames(typeof(KnownColor))             //collection of color names from the System.Drawing.KnownColor enum
         .Select(x=>Color.FromName(x))             //convert the color names to Colors
             .Where(x=>!x.IsSystemColor&x.A>254)   //filter out unwanted colors
                 .OrderBy(x=>Math.Abs(x.R-C(s).R)  //order by increasing distance
                            +Math.Abs(x.G-C(s).G)
                            +Math.Abs(x.B-C(s).B)) 
                     .First().Name                 //return the closest color's name

ด้วยเหตุผลบางอย่าง Tio บ่นว่าเนมสเปซ 'การวาด' ไม่มีอยู่ในเนมสเปซ 'ระบบ' แม้จะมีโครงการที่มาโมโนระบุว่ามันเข้ากันได้ มันทำงานได้ดีใน VisualStudio แม้ว่า

แก้ไข: เห็นได้ชัดว่ามันยังไม่ได้นำไปใช้กับ Tio!

ลองออนไลน์!


7
C # out-golfing ภาษากอล์ฟครั้งเดียว มีคนแรก ...
Darrel Hoffman

2
ฉันประหลาดใจที่ Javascript ไม่มีวิธีเข้าถึงรายการ แต่ C # ทำ
JollyJoker

1
@JollyJoker คำตอบ Node.js นี้จะนำเข้าแพคเกจที่มีข้อมูล
Arnauld

14

Node.js , 1488 ไบต์

รับอินพุตเป็นจำนวนเต็ม 24 บิต เอาต์พุตเป็นตัวพิมพ์เล็ก

v=>(require('zlib').inflateRawSync(Buffer('TVRbm6o4EPxLE27CowziDOiIV+bwFkkrWUPCBBg/9tdvLurZFzGX7uqqrs6Z4fr2xvHv5OYEy9uZjRC3QOjY6r/oaH4X+ugqAXiWI/P1M28AzGxQPWHuBBkB6PrbpCPmyZs+GEb5Mwrag/O9sEn7TlJ+NSnCr4TRFk7z/+25mc7l5i0lnF6bQef6Pn6tiCBXkHo12yxTpo96wCbEqfbxRUjoB7tcxfvn0fJ4POgyeoYHuEo8IafINaY59co8exT1uJ+Uq/hVsn8KUykmzDTqzin6AcD8n/nb3Sur3nDSD9cmegUf5hHlhF6F6ySOviwY/bWwi/UO1ZiA4baIj1EtJL8wcbf8gspLJJyhrnE3yo6BExUbmx3/jLjFSis4pitCW83I/SrTVyEo3uQGiEh8Rpvi80U8+OMXVrXnTnTKowf7Z7i/fFsxfOdWx9l6XjdYDhLGHrxwvvkL75fqKwRHoS3RtahFsDEl5U8TRMudBbXrVP/8UsFgcOMP4xwJBPmlsVeLr8AH7J56TAiDsxR3nmTvRulHf4LotDQJzQptlsgyeFTxeUr1bYuwT/cdZlbyoDog0wRZN5TMy3wCpgS3PCNn0VPgHM927smgBvvvwhpeCRc/7GYEOq0KE2TjZ3mkIf6avPiOLd+nVVAQvXfiTmxr/ez9QlVvJa1vaLc01K6CEeBSkLDyfcvGVulk6zcp+slU5HrZUt++NfhG0Tote8p+QXpRVtgYy1mpGZb+h3Ye5npxWKQdyDF0dnUjaqEbHZzmswHzRbl4KKmmIt+ehob2A4OgLP0HfpI5r+Lm8VEzfaEgL9jVkra94GV8uGLK+7OQArnrTcfGVo3Z4TxKNt2FICgLtwbKTPYs8hj+Ba4kCedLO0eYtYK7u31p8wdlFZrWPdFz13ZdDQpmTpgHRobc32BGa+Nc92vWCA4TgTtKEvzvKCHtMSdWPd8LonsDeEBbd3YGegUvL+4NHaBvxQ2KlvKhloBbVEXXRvSDOfOCuLClOX78hflAf0YwJ6uZmiUOvKqshM86rSvQHzUNRD2rKsP2XYu1zOcPc89c/UZ2lN/cU6jYcPWoAYnyZBAtHoRfxY0Y9DGKCsPWizbWuPqq8xlae5mqPLS222Vgdk3Wz8hEVwtdlJd8d4Drphsvl+2HeuPxP8IQ2HutUO9LTzkKyjPtFbG0Vf2flOHgcGaY1w0Qg0JQoprR4QmryG6/eTZPqd434ZuazL5RtKtEv2LKlbf8yEDFKQtdLoInB/WyKR4Gtuq5uM+tSvu1KdougpD+Cjktza30Pw','base64'))+'').replace(m=/([a-z]+)([^a-z]+)/g,(_,s,d)=>[e=0,8,16].map(x=>e+=Math.abs((v>>x&255)-(t>>x&255)),t+=parseInt(d,36))|e>m||(o=s,m=e),t=0)&&o

ลองออนไลน์!

อย่างไร?

สตริงที่บีบอัดมีความยาว 1683 อักขระและมีลักษณะดังนี้:

"black0navy3KdarkblueBmediumblue1Ublue1EdarkgreenJK1green5J4(…)lightyellow68ivoryGwhiteF"

สีจะเรียงลำดับจากต่ำสุดไปหาค่าสูงสุด แต่ละสีถูกเข้ารหัสเป็นชื่อของมันในตัวพิมพ์เล็กตามด้วยความแตกต่างระหว่างค่าของมันและค่าก่อนหน้าใน base-36 และในตัวพิมพ์ใหญ่:

black[0]        | 0x000000 + 0     --> 0x000000
navy[3K]        | 0x000000 + 128   --> 0x000080
darkblue[B]     | 0x000080 + 11    --> 0x00008B
mediumblue[1U]  | 0x00008B + 66    --> 0x0000CD
blue[1E]        | 0x0000CD + 50    --> 0x0000FF
darkgreen[JK1]  | 0x0000FF + 25345 --> 0x006400
green[5J4]      | 0x006400 + 7168  --> 0x008000
...             | ...
lightyellow[68] | 0xFFFF00 + 224   --> 0xFFFFE0
ivory[G]        | 0xFFFFE0 + 16    --> 0xFFFFF0
white[F]        | 0xFFFFF0 + 15    --> 0xFFFFFF

แสดงความคิดเห็น

v =>                            // v = input
  ( require('zlib')             // using zlib,
    .inflateRawSync(            // inflate the
      Buffer(                   //   buffer obtained by
        'TVRbm(…)Pw',           //     converting this string
        'base64'                //     encoded in base-64
      )                         //
    ) + ''                      // and coerce it back to a string
  ).replace(                    // on which we invoke replace():
    m =                         //   initialize m to a non-numeric value
    /([a-z]+)([^a-z]+)/g,       //   for each color encoded as ...
    (_, s, d) =>                //   ... s = name, d = delta in base-36:
      [e = 0, 8, 16]            //     using x = 0 for blue, 8 for green and 16 for red,
      .map(x =>                 //     compute the error e:
        e +=                    //       add to e:
          Math.abs(             //         the absolute value of the difference between
            (v >> x & 255) -    //           the component of the target color
            (t >> x & 255)      //           and the component of the current color
          ),                    //
        t += parseInt(d, 36)    //       start by adding the delta to t
      ) | e > m ||              //     end of map(); if e is less than or equal to m:
        (o = s, m = e),         //       update o to s and m to e
    t = 0                       //   start with t = 0
  ) && o                        // end of replace(); return o

ทำไมไม่บีบอัดรหัสของคุณด้วยสายข้อมูลร่วมกันแล้วประเมินมัน? คุณเคยลองไหม
TSH

@tsh รหัส JS ไม่บีบอัดได้ดีพอที่จะชดเชยการโอเวอร์โหลดที่เกิดจากการเข้ารหัส base64 ดังนั้นมันจะนานขึ้น มันอาจจะถูกเขียนใหม่เพื่อทำให้เป็นมิตรมากขึ้น (เช่นโดยการคลี่แผนที่ลูป) แต่ฉันสงสัยว่ามันจะเพียงพอ
Arnauld

คุณสร้างชื่อสีด้วยตัวเองไม่ได้เหรอ? อาจเป็นวิธีที่ดีกว่า / เร็วกว่าในการทำ แต่คุณสามารถดุร้ายมัน: q=i=>{b=document.createElementd ;b.style.color=i;document.body.appendChild(b);h=getComputedStyle(b).color;y=h.slice(4,-1).split(",").map(e=>e.trim());return h!="rgb(36, 39, 41)"?[y.reduce((a,e)=>a+parseInt(e),0),parseInt(y.map(e=>parseInt(e).toString(16).padStart(2,"0")).join``,16)]:0};a=[];for(i=0,t="0";i<7988090793663851220822006848646;i++,t=i.toString(36)){(!t.match(/\d/g)&&q(t))?a.push([t,...q(t)]):0}(โปรดทราบว่าrgb(36, 39, 41)การเปลี่ยนแปลงด้วย ...
Geza Kerecsenyi

... สไตล์ชีทอันนี้ใช้ได้กับ StackExchange - เป็นเพียงสีตัวอักษรเริ่มต้น) นอกจากนี้ฉันไม่ทราบว่าสิ่งนี้มีความสำคัญหรือไม่เพราะใช้เวลาหลายวันในการรัน แต่ฉันทดสอบในระดับน้อยและสามารถดูได้ (ลองเปลี่ยน 7988090793663851220822006848646 ด้วย 39999)
Geza Kerecsenyi

9

เยลลี่ , 1,015 914 ไบต์

“¥.⁻ḲU3ŒẆȯ§.eḊC¤ŀ"}Ʋ59£Uŀ'⁶ɠıṇȥLcṆɓ?^¢Ỵɠ.ȮẆẆḊqʠu½ỊƑfĠ⁴ µ¥ɓƭÑUC½ṁUĿẆṃ⁹S/÷Ɓɗ>ṭ"»Ḳ33r64¤,Ọy“µṂFŀƲOḌẇȤạ2œxṾk,E.LẸpḄ2s⁵Ṛç¦ṆkAẋ=çw©ḌĊẒƤm`;ṄȧṄİɦbṠṆṛ⁴Ḟ[CƊėQẏƑ<:⁾Þḍ?çⱮ3ƈṗ¬!7Hẏywœ⁽Ẉ¤ṾƈpHṗ(⁾ƲḢdƲḃ'¦ṇ9ẏP¡ċ⁻ȤẒṬf§®ṬẒpJÞẒẸṪÄƊhḊḃ7ʠ%ƈėc+ġȦı©ḄO⁸ṗ:WṠß@Ä|ż_g¹Ʋ®[*ẹ5¡Ẹßė¶~[ȷ'ȧẊṖZẋ¦ẉ7Ġ⁽ė⁽ƁLP`²¶⁶* Ġv|$ṭⱮẋ_ƭø¦Ẇ-*ɓɼhCUṙƭƭƓS7Ø⁵¤³¢Ʋẉ!§ḟƇṣḟṛḳṠƬ4ẓḢTḌZżƇȦQxw}ḃçṣȮv⁷ȤĊẏyNỵʠÄ⁸hLġị³TİọȧfÞȤTO&ṡ°⁼`WẹạẇḂvðFmż]ɦo½ƓṂḟȯ#Æ⁺T)ṃç=ḣṆø⁽Wpʂqṫ&⁷¶S®¢ð:\ṚMĖḌ½⁽_ạ⁵]Xlȷg¿£⁺x0ṁo8ẒṛżøuɲẈ®§Bṡr:ċ³ḷb|Mku¬V°ḟƲ!ɦɠ4¬>ḷ^XḶɼ5[ṇƑȮ.XȮƙẎbḊÐþFæṁoOṗ⁺mṪ-&ƊṅƑḋ$!`€ɓḥƤ¡ɗbH⁻ḃÄ⁵!Ñėḅƈḳm⁴ḳcÐⱮ⁷ỤḍġḷȥṀSĖ»Ḳ
“⁸¢!İƝ\8¢[V⁸¢Ñ"ĠƙḶ-Æ⁷⁾Æ⁵¢⁸¢ƙhLṂS×®Ẓ©Aḅ¦ṚÆ&nj£ÇØ¿waþM=ÆḂḌ¢³(Ñḷx¦DẊ¢Aẓ©ḋ¬!ƁV  ṾÐẉœ¦2Ä¢⁼C®⁶ẇ£ḋṀ¤çẠÐȧIæḌH€5ẋ¥®⁹µ⁻£⁴⁸¢AƇ¢⁸¢£*ç-Ụz¬>ƈ£ʋ¢^ạṭ(ÇṪĠ¤Çŀ¬ÇḞ¢ṪĠÐCȥṖÞ¦ø}×⁹YÐƬAÇ×CÆævÇ#©ḥƙ£sVṀṙ¤ỊAÞtỤ¦AǬ⁶ʠ¤⁼ƈµ£ŒÞ¿§Œ÷~2~Ðɲċ×⁻¤SƤÐ}Z¦Fƙ°¹£Ḣ©£Ṁx£⁹j£Ƒs¤ɓ8¬_ḶØz°®ʂƬÐḢ@¢ẉ€¦ỴA¢Ä8gß-Ė⁸¿zṛ¤mGKÄœ>jµ\ạ¥>R¢ƤÐƤœⱮpµỴI¤Œ¤a<[Ɱa]ṠŒɲB"'(?ŀÆȦ6ȯœ|Dy¿1€ƤØ-WXßm€v¤Uнµẋ¦iœg€Ḥ£0-‘©ṛ®Ḣ¤⁺;$%¡3¤®Ð¿Ḋḅ249:3ÄŻ,b⁹UạN,§ʋ@€/MṪị¢

ลองออนไลน์!

ขอบคุณ @Arnauld สำหรับคำแนะนำที่บันทึกไว้ 41 ไบต์!

โปรแกรมเต็มรูปแบบ ใช้สีเป็นจำนวนเต็ม 24 บิตเป็นอาร์กิวเมนต์และส่งคืนชื่อสี

คำอธิบาย

ลิงค์ผู้ช่วยเหลือ

ชื่อสี เก็บไว้โดยใช้สตริงที่บีบอัด แต่ด้วยคำทั่วไปที่ถูกแทนที่ด้วยอักขระ ASCII เดียวในช่วง 33 ถึง 64

“¥...»                  | Compressed string "blue brown coral..."
      Ḳ                 | Split at spaces
       33r64¤,          | Pair the numbers 33 to 64 with these words [[33,34,35,...],["blue","brown","coral",...]]
              Ọ         | Convert the numbers to Unicode characters [["!",'"',"#",...],["blue","brown","coral",...]]
               y“µ...»  | Translate the compressed string "black navy %! ..." using the mapping generated above
                      Ḳ | Split at spaces

ลิงค์หลัก

ขั้นตอนที่ 1: เริ่มสร้างรายการหมายเลขสี การเพิ่มขึ้นระหว่างหมายเลขสีจะถูกเก็บไว้ระหว่าง 1 และ 3 ฐาน 249 หลัก การเพิ่มขึ้นจะถูกคูณด้วย 3 แปลงเป็นฐาน 249 จากนั้นจำนวนหลักลบด้วย 1 ได้ถูกเพิ่มเข้าไปในจำนวนนัยสำคัญน้อยที่สุดก่อนที่จะกลับคำสั่งของตัวเลข

“⁸...‘©                | Copy compressed integers 136,1,33,198,... to register
       ṛ               | Right value (will yield value of the following):
                 ¤®Ð¿  | - While the register is non-empty, do the following, collecting values as we go:
        ®Ḣ¤            |   - Take the first value from the list held in the register, popping it from the list, x
              %¡3      |   - Repeat the following (x mod 3 times)
           ⁺;$         |     - Concatenate the first value from the list held in the register, popping it from the list
                     Ḋ | Remove the first item (will be 'None')

ขั้นตอนที่ 2: เสร็จสิ้นการสร้างหมายเลขสีและค้นหาอินพุต

ḅ249                     | Convert from base 249 to integer
    :3                   | Integer divide by 3
      Ä                  | Cumulative sum: 128,139,205,255,25600,...
       Ż                 | Prepend zero
        ,                | Pair with input
         b⁹              | Convert to base 256: [[0],[128],[139],[205],[255],[100,0],...], [input in base 256]
           U             | Reverse order of innermost lists (so RGB becomes BGR, GB becomes BG and B remains as B); this is because colours with no red component will be a list with only two members, and colours with only blue will just have one member
                ʋ@€/     | Reduce using the following as a dyad for each; effectively calls the following once for each colour with the reversed base-256 colour as left argument and the reversed base-256 input as right
            ạ            | - Absolute difference of the colour and the output of stage 1
             N           | Negate
              ,          | - Pair with the colour
               §         |   - Sum each of these
                    M    | Indices of maximum
                     Ṫ   | Tail (will be the index of the largest colour value)
                      ị¢ | Index into helper link

สีจะถูกย้อนกลับก่อนที่จะทำการเปรียบเทียบเพราะสีที่ไม่มีองค์ประกอบสีแดง (ตัวอย่าง) จะปรากฏเป็นรายการส่วนประกอบ 2 รายการ

ลิงค์ TIO สร้าง 10 สีแบบสุ่มและแสดงผลลัพธ์ดังนั้นจะแตกต่างกันในแต่ละครั้ง


อินพุตอาจเป็น 24 บิต ฉันได้กล่าวไปแล้วว่ามาตรฐาน I / O ใช้อยู่
Geza Kerecsenyi

@GezaKerecsenyi ขอบคุณ คุณต้องบอกว่ามันต้องเป็นเลขฐานสิบหกหกหลักดังนั้นจึงเป็นการดีที่จะให้ความกระจ่างในคำถาม
Nick Kennedy

i×4+ni×3+nin

นี่คือรหัส JS เพื่อแสดงความหมายของฉัน (นี่เป็นรุ่นที่แน่นอนพร้อมการเข้ารหัส + การถอดรหัสขออภัยเกี่ยวกับการโพสต์หลายรายการ)
Arnauld

@ Arnauld ขอบคุณ ฉันต้องการอัพโดยใช้ฐาน 249 โดยสังเขปฉันเพิ่มการคูณด้วย 3 แปลงเป็นฐาน 249 กลับคำสั่งของตัวเลขและเพิ่มความยาว -1 เป็นหลักแรก สิ่งเหล่านี้จะถูกเข้ารหัสเป็นอักขระ Jelly สำหรับการถอดรหัสฉันจะแสดงตัวเลขตัวแรกจากนั้นก็เติมตัวเลขอีกตัวหนึ่ง (ตัวแรกตัวที่ 3) และต่อกัน (กลับลำดับในกระบวนการ) ฉันทำซ้ำจนกว่าจะไม่มีตัวเลขเหลืออยู่ นี่จะถูกแปลงกลับจากฐาน 249 เป็นจำนวนเต็ม เหตุผลที่ 249 คือ 250 เลขนัยสำคัญน้อยที่สุดไม่จำเป็นต้องเป็น 3 เท่ากัน
Nick Kennedy

3

ภาษา Wolfram (Mathematica) ขนาด 164 ไบต์

หมายเหตุ:ใช้งานได้ใน Mathematica 12.0 เท่านั้นเนื่องจากข้อผิดพลาดในรุ่นก่อนหน้า นี่หมายความว่าไม่มีลิงก์ TIO

g[c_]:=Last@Keys@SortBy[Round[255List@@@<|"HTML"~ColorData~"ColorRules"~Join~{"RebeccaPurple"->RGBColor@"#639"}|>],{-Total@Abs[IntegerDigits[c,256,3]-#]&,Total,#&}]

กำหนดฟังก์ชั่นgซึ่งใช้จำนวนเต็มเป็นอินพุต กรณีทดสอบ:

AssociationMap[g, {327581, 3483113, 2820178, 4358965,
  2058772, 13569770, 8698378, 2897368, 3896382, 12856883}]

(* <|
  327581 -> "MediumSpringGreen",
  3483113 -> "RoyalBlue", 
  2820178 -> "MidnightBlue",
  4358965 -> "DarkOliveGreen", 
  2058772 -> "ForestGreen", 
  13569770 -> "Magenta",
  8698378 -> "Olive",
  2897368 -> "RoyalBlue",
  3896382 -> "DarkOliveGreen",
  12856883 -> "Brown"
|> *)

น่าเสียดายที่มีไม่กี่ไบต์ในการเพิ่ม "RebeccaPurple" ลงในรายการสีในตัวซึ่งหายไปด้วยเหตุผลบางประการ ส่วนที่เหลือนั้นค่อนข้างตรงไปตรงมาเราแค่เรียงลำดับสีตามระยะทางไปยังอินพุททำลายความสัมพันธ์กับผลรวมของค่าช่องทางแล้วลำดับที่แน่นอน


1
RebeccaPurpleเป็นของใหม่ (ish) และเครื่องบรรณาการให้กับลูกสาวของเอริคเมเยอร์ของ: lists.w3.org/Archives/Public/www-style/2014Jun/0312.html ฉันจะยกระดับเป็นการปรับปรุงคุณสมบัติด้วย Mathmatica
Robin Whittleton

2

JavaScript (Firefox) 1,050 ไบต์

c=>(b=document.body,_.match(/.[a-z]*/g).map(t=>getComputedStyle(b,b.style.color=t).color.match(/\d+/g).map((v,i)=>s+=Math.abs((c>>16-8*i&255)-v),s=0)|m>=s&&(m=s,r=t),r=m=c),r)
_='BlackNavy}~x~B2e}|G^ETeU}cy@Deeps,}t`xs*LimeS*Cy@Midnight~Dodg9~{s:GFo^1|S:|}s]JLime|xs:|T`RoyU~Steel~}s]~xt`Indigo}o6|Cadet~C?nfl59~Rebeccap<xa;DimJS]~O6drabS]J{s]Jxs]~Lawn|Chart^useA;Maro4P<O6GrayG^yS,{s,B2ev[}0}m+Saddleb>}s:|{|xp<}v[7|}?/YZ|SiEnaB>}J{~G^EyZ7t`{1eel~P5d9~Fi^brick}g_x?/Rosyb>}khakiSilv9xv[0Indi@0P9uChoco]T@{JT81leOr/G_7v[0Crims4GaQsb?oP2mBurlywood{cy@3}s=V[7g_{c?UKhakiAlice~H4eydewAzu^S@dyb>Wh:tBeigeWXsmokeMQtc^amGho1wXS=AntiquewXLQE{g_yZOldlaceRedM+Deep.Or-0TomatoHot.C?U}?-{s=Or-{.PQkGoldP:chpuffNavaj5XMoccasQBisqueMi1yroseBl@ched=dPapayaw8p3b2shS:shellC?nsilkLem4c8ff4Fl?UwXSn5YZ{yZIv?yWX~b2e}Dark|g^E{LightxMedium`urquoise_oldErod^re]late[ioletZell5X8teUalQinJg^yEen@an?or>r5n=Um4<urple;quamarQe:ea9er8hi7PUe6live5ow4on3LavEd92lu1st0^d/c8d.pQk-@ge,ky~+agEta*prQg|';for(i of'*+,-./0123456789:;<=>?@EJQUXZ[]^_`x{|}~')with(_.split(i))_=join(pop())

ภาษา JavaScript ที่สามในคำถามนี้ตอนนี้ ...

getComputedStyleส่งคืนสีในrgb(x, y, z)แบบฟอร์มทุกครั้งหากalpha == 1บน Firefox

_BlackNavyDarkblueMediumblueBlueDarkgreen...Whiteตัวแปรถือสตริงที่มีชื่อสีในรูปแบบ

บันทึก 11 ไบต์ด้วย Kevin Cruijssen โดยการลบสีที่ไม่จำเป็นออก บันทึก ~ 350 bytes ขอบคุณ Arnauld โดยแนะนำอัลกอริธึมการบรรจุที่แปลก


คุณควรบันทึก350+ไบต์โดยRegPack'ingสตริงของคุณหรืออาจเป็นรหัสทั้งหมดในครั้งนี้ ;)
Arnauld

บันทึกสองสามไบต์โดยกำหนดdocument.bodyให้bภายในgetComputedStyleช่วยให้คุณสามารถลบวงเล็บที่ล้อมรอบ
Shaggy

FuchsiaMagentaและAquaCyanสามารถเป็นได้ทั้งสองอย่างแทนที่จะเป็นทั้งคู่เนื่องจากเป็นGray/Greyรหัสสีเดียวกัน (เหมือนกัน)
Kevin Cruijssen

@Shaggy แต่วงเล็บยังคงจำเป็นโดย,rอาจ
TSH

@tsh ใช้&&rแทน
Shaggy

2

JavaScript (Node.js) + color-nameแพ็คเกจ, 259 279 284 259 278 282 299 312 364ไบต์

c=>{w=[]
K=Object.keys
for(x in d=require('color-name')){(w[W=(p=i=>Math.abs(d[x][2-i]-(255&("0x"+c)>>8*i)))(2)+p(1)+p(0)]=w[W]||[]).push(x)}S=[]
for(s of r=w[K(w)[0]]){(S[z=(W=d[s])[0]+W[1]+W[2]]=S[z]||[]).push([d[s],s])}return S[K(S).pop()].sort().pop()[1]}

ลองออนไลน์!

แสดงความคิดเห็น:

c=>{w=[]                      // build dict of arrays of names, by color distance:
K=Object.keys
for(x in d=require('color-name')){
  (w[W=
      (p=i=>Math.abs(d[x][2-i]-(255&("0x"+c)>>8*i)))(2) + p(1) +p(0)
    ] = w[W]||[]).push(x)
}S=[]                         // distances were ordered by Object.keys()
for(s of r=w[K(w)[0]]){       // build dict of [[RGB, name]+] by channel sum for distance ties:
  (S[ z= (W=d[s])[0] + W[1] + W[2] ]= S[z]||[]).push([d[s],s])
} return S[ K(S).pop()        // highest channel sum
          ].sort().pop()[1]}  // [name of] highest RGB

ฉันต้อง

npm install color-name

เพื่อให้ต้องการ () เพื่อทำงาน ฉันไม่คิดว่าฉันสามารถติดตั้ง npm ได้บน TIO ดังนั้นฉันจึง hardcoded พจนานุกรมในส่วนหัว

แพคเกจนี้มี 148 รายการเหมือนกันกับหน้า w3schools ชื่อเป็นตัวพิมพ์เล็ก ฉันไม่รู้ว่าใครเป็นคนสร้างมันขึ้นมาและเมื่อใดที่ฉันเพิ่งพบมันในขณะที่ googling มีแพ็คเกจ Debianสำหรับมันดังนั้นฉันคิดว่ามันเก่ากว่าคำถามนี้

[แก้ไข: การลดขนาดที่สาม / การยกเครื่องครั้งใหญ่]
[แก้ไขลำดับที่ 5 / การแก้ไข: รุ่นนั้นมี 282 ไบต์ แต่ไม่มีการขาดไทม์เบรคตามค่า RGB ฉันไม่คิดว่าฉันจะแก้ไขได้และทำให้มันเล็กกว่าอันนี้ดังนั้นฉันจึงลบรหัสนั้นออกจากโพสต์]

คราวนี้ฉันเขียนโค้ดใหม่เกือบทั้งหมด ฉันรู้สึกว่ามันแตกต่างจากเมื่อก่อนมันไม่มีเหตุผลที่จะเก็บประวัติไว้ในโพสต์

@Shaggy บันทึกฉัน 4 ไบต์จากเวอร์ชันล่าสุดโดยไม่ต้องใส่วงเล็บในพารามิเตอร์ฟังก์ชันลูกศรเดียว ตอนนี้มีทั้งหมด 6 ตัวดังนั้นโดยทั่วไปฉันต้องขอบคุณ 12 ไบต์

ฉันเปลี่ยนจากการสร้าง dicts / รายการด้วยตนเองเป็นใช้mapและfilterทุกที่ซึ่งเปิดใช้งาน / พร้อมรับการปรับโครงสร้างจำนวนมาก ฉันพบสถานการณ์เพิ่มเติมบางอย่างที่ฉันสามารถกำหนดตัวแปรได้ในภายหลัง

[แก้ไข: การลดขนาดที่ 4 กลับไปที่ราก]

ภายในไม่กี่นาทีหลังจากที่ยกเลิกประวัติศาสตร์ (ด้านบน) ฉันได้ตระหนักถึงความผิดพลาดของฉันในการบอกว่า
ฉันใช้บทเรียนที่เรียนรู้ไปแล้วกับโค้ดเก่าและฉันเห็นว่าการเรียงลำดับที่สอง () ไม่มีประโยชน์ ดังนั้นตอนนี้รหัสนั้นล่วงหน้า 4 ไบต์
[แก้ไข: 4.1th: DUH! ทุกประเภทไม่มีจุดหมาย -19 ไบต์เพิ่มเติม]

[แก้ไข: การทำซ้ำครั้งที่ 5 เพิ่มขึ้น แต่ตอนนี้ (หวังว่า) ถูกต้อง]

@ Lukas Lang ชี้ให้เห็นว่ารหัสของฉันไม่ถูกต้องในกรณีที่ผลรวมของช่องถูกผูกไว้ ฉันรู้สึกผิดที่ไม่เคยเกิดขึ้น
ในการแก้ไขฉันต้องกรอกข้อมูลอาร์เรย์Sด้วยคู่ [RGBarray, name] แทนที่จะเป็นแค่ชื่อ ด้วยวิธีนี้การเรียงลำดับอาเรย์เริ่มต้นทำให้งานเสร็จสมบูรณ์

[แก้ไข: การลดอันดับที่ 6 - ของขวัญจากอาณาจักรที่สูงกว่า]

@Shaggy ได้รับเครดิตสำหรับรอบนี้ เป็น.reverse()[0] .pop()เห็นได้ชัดว่า ... นอกจากนี้การแปลงชนิดโดยปริยายทำให้การทำงานแทน('0x'+c) parseInt(c,16)และถ้าคุณเข้าใจถูกต้องตัวแปรทุกตัวสามารถกำหนดได้ในการใช้ครั้งแรก เวลานี้ที่ถูกและWp


12
หากคุณมีแพคเกจที่จำเป็นซึ่งไม่ใช่ส่วนมาตรฐานของภาษานั้นจำเป็นต้องอยู่ในส่วนหัวของภาษาที่ด้านบนของรายการของคุณ (เช่น JavaScript (Node.js) + color-name) ซึ่งหมายความว่ามันจะแข่งขันกับรายการอื่นโดยใช้แพ็คเกจเดียวกัน แต่ไม่ได้โดยตรงกับรายการ JavaScript (Node.js) อื่น ๆ
Nick Kennedy

นั่นทำให้รู้สึก ขอบคุณ!
Paul Thomann

3
หากฟังก์ชันลูกศรมีเพียงพารามิเตอร์เดียวก็ไม่จำเป็นต้องอยู่ในวงเล็บ
Shaggy

1
หากฉันเข้าใจผิดรหัสจะล้มเหลวในกรณีที่จำเป็นต้องใช้กฎการผูกไทม์ที่สองเช่นe8fcf8: ทั้งสองAzureและMintCreamมีระยะห่างจาก18สีนั้นและผลรวมของแชแน750ล ดังนั้นผลที่ควรจะเป็นในขณะที่ผลตอบแทนรหัสนี้MintCream Azure
Lukas Lang

1
การปรับแต่งเล็กน้อยจากโทรศัพท์ของฉัน: tio.run/…
Shaggy

1

05AB1E , 1175 ไบต์

.•ŒRǝJÖ¤|DÕGø∊ŸγÜuÕפJÓΩaĀhºΔè₆ìkh¥ù§¸β?|"qтy¥Œ›ιM?z*Ω3¿ƒLò·¡ËÌóñD#Ë‰в††α½ÅÎëLpÄäÍEáyø‡§*ßtÓñ7тÜöãô±‘§—ÄGfΔ½~10'–ßaÔ´?ç"&$&¾¬ÍTʒ}M‰8βÔŽÙûQ[мvαн'YW:ΘÌiнœ+ĀβWŬŽø%ð°¤]γθγçkÌã©Ð:8•
#`“ƒÏª©–°0‡—–í0‡—‡—–°0ˆ¨ˆ¨¤Æl–°ÿ•³0¤Ð0‡—–°ÿ–í0Ž¹0ˆ¨ë¿Ž¹0ˆ¨Ü„Àš0‡—·¡r0‡—‡Ž0í™0ˆ¨ï×0ˆ¨í™0ˆ¨–°s0Ž¦0°¯ë¿0ˆ¨–í0í™0ˆ¨ ÿïˆ0‡—–Í0‡—–°s0Ž¦0‡—–íÿ ÿ–°0Ê£0ˆ¨ ÿ0‡—ÃÅ0žç0‡—Ôî0´Ò–í0Ü„0›Ðæá0°¯ s0Ž¦0‡—Ê£ÿ s0Ž¦0°¯¦º0Ž¦0°¯–ís0Ž¦0‡—į0ˆ¨œëre0€ÅÜ„0›Ð ÿ´ÒÊ£°¯¤Ð0‡—‡Ž0¤Ð0‡—‡—ÿ–°0†¾–°m0î±a»Ïÿ0ŽÌ–°0í™0ˆ¨‡Ž0ˆ¨–í0´Ò–°ÿæ§0ˆ¨–°ÿŠÛ0ˆ¨ ÿŽÌ–°0°¯‡Ž0‡—ˆ¨0ŠÛæ§ÿ‡Ž0–Í0‡—¼ì0‡—ŠÄ0Ñ´–°0ž®0»³–íÿ ÿ0ŽÌ–°ÿ‹ß–íÿ0†¾•‹0†¾¾ç¨ËÇ⇎0°¯€Œÿ ÿž®0»³æ§ÿ0†¾ ÿÆŠÿ ÿ ÿ0–œ‡Žÿ ÿ–°0ÇÝ ÿæ§0ž®0»³‡Ž0Í€ ÿ¿í0‡—Æàÿ ÿǨ0ŽÌÍÍ ÿ„¸0³«¼Õ0¥â·ä0„¸ÇÝ°Š0„¸ƒ£n‡Ž0ž®0»³0ŠÛ„Ï0ÕÚ†¾ m0î±a•³0™Å›È0†¾æž…ß0™ÅÍ€–°0›È‡Ž0ÇݛȇŽ0™Å™Åˆ° p0‚Ìÿ ÿ0„¸ ÿ ÿ ÿ0šÓ ÿ ÿ ÿí™0¬•ÃÅ0»»ËÃÿÄ‚0„¸œÒŠÛ‡Ž0ŠÛ؉„¸“„0 K#•zÑĪåð≠K¯&u+UhĆõ;Éðf.ã₂=нH,ª@O¶ü˜ˆ₂Ɔ¥2Œ’Ktθu1Sнdw΀(#ç¹ü‹U¹³αh+8R∍±æ”ÇKë₆ßõk₃¿θòĀηú¿ζвî!Vs©₂™CÖ.∍JнαθWÀhzαÐé3¾¯|ë¡×°'βâá—P‘Å_uë_§₃P∊%ý/=i]¥5óO₃^E‘[∞₆ć:βU=J€¦†˜X'Žāìd4Ā’δ‹a°∊›ÊÐƶoÂö mвæÁƵ¨¼Yü“à §‚₂¾¤н7Þ9úÂuœ¿®jF™SΛ¬ìr½ƒxßU‘Lβ7≠°oι—ĀÅýÆgBÐγö™α₆©vÝeEXεò₁Uт3ÈĀ(wº4{ºö쾫Â
åUøò${J#₃O<!øN”;GÑéÈfm ½™×γäJǝõ¥àÐι)λÓ:α–ù?6¦¨·ã™ζÙ4ÍHd›-Iž|ï¦{Ö9ÊàÛ§¥–Σÿ%ć8ùćYáþǝC±;••O褕в.¥εI‚₄S₁β+₁∦`αO}Wkè

ต้องใช้เวลาสักพัก .. 139 สีในการสร้างสตริงของ .. >.>

รับอินพุตเป็นจำนวนเต็ม 24 บิตเพื่อบันทึก 1 ไบต์

ลองออนไลน์หรือตรวจสอบกรณีทดสอบอีกสองสามข้อ (ทั้งคู่ได้รับการแก้ไขเล็กน้อยเพื่อรับสตริงเลขฐานสิบหกเป็นอินพุตแทนเนื่องจากง่ายต่อการทดสอบ)

คำอธิบาย:

ก่อนอื่นเราสร้าง color-strings ทั้งหมด:

.•ŒRǝJÖ¤|DÕGø∊ŸγÜuÕפJÓΩaĀhºΔè₆ìkh¥ù§¸β?|"qтy¥Œ›ιM?z*Ω3¿ƒLò·¡ËÌóñD#Ë‰в††α½ÅÎëLpÄäÍEáyø‡§*ßtÓñ7тÜöãô±‘§—ÄGfΔ½~10'–ßaÔ´?ç"&$&¾¬ÍTʒ}M8βÔŽÙûQvαн'YW:ΘÌiнœ+ĀβWŬŽø%ð°¤]γθγçkÌã©Ð:8•
                '# Push compressed string "chiffon lavenderblush papayawhip blanchedalmond misty bisque moccasin navajo puff beige azure dew khaki violet lavender cyan burly plum boro crimson violet orchid tle violet khaki rosy orchid turquoise sienna orchid violet dle violet maroon drab cadet indigo turquoise turquoise cyan turquoise steelblue"
  #              # Split this string on spaces
   `             # Push each string separately to the stack
    “ƒÏª©–°0‡—–í0‡—‡—–°0ˆ¨ˆ¨¤Æl–°ÿ•³0¤Ð0‡—–°ÿ–í0Ž¹0ˆ¨ë¿Ž¹0ˆ¨Ü„Àš0‡—·¡r0‡—‡Ž0í™0ˆ¨ï×0ˆ¨í™0ˆ¨–°s0Ž¦0°¯ë¿0ˆ¨–í0í™0ˆ¨ ÿïˆ0‡—–Í0‡—–°s0Ž¦0‡—–íÿ ÿ–°0Ê£0ˆ¨ ÿ0‡—ÃÅ0žç0‡—Ôî0´Ò–í0Ü„0›Ðæá0°¯ s0Ž¦0‡—Ê£ÿ s0Ž¦0°¯¦º0Ž¦0°¯–ís0Ž¦0‡—į0ˆ¨œëre0€ÅÜ„0›Ð ÿ´ÒÊ£°¯¤Ð0‡—‡Ž0¤Ð0‡—‡—ÿ–°0†¾–°m0î±a»Ïÿ0ŽÌ–°0í™0ˆ¨‡Ž0ˆ¨–í0´Ò–°ÿæ§0ˆ¨–°ÿŠÛ0ˆ¨ ÿŽÌ–°0°¯‡Ž0‡—ˆ¨0ŠÛæ§ÿ‡Ž0–Í0‡—¼ì0‡—ŠÄ0Ñ´–°0ž®0»³–íÿ ÿ0ŽÌ–°ÿ‹ß–íÿ0†¾•‹0†¾¾ç¨ËÇ⇎0°¯€Œÿ ÿž®0»³æ§ÿ0†¾ ÿÆŠÿ ÿ ÿ0–œ‡Žÿ ÿ–°0ÇÝ ÿæ§0ž®0»³‡Ž0Í€ ÿ¿í0‡—Æàÿ ÿǨ0ŽÌÍÍ ÿ„¸0³«¼Õ0¥â·ä0„¸ÇÝ°Š0„¸ƒ£n‡Ž0ž®0»³0ŠÛ„Ï0ÕÚ†¾ m0î±a•³0™Å›È0†¾æž…ß0™ÅÍ€–°0›È‡Ž0ÇݛȇŽ0™Å™Åˆ° p0‚Ìÿ ÿ0„¸ ÿ ÿ ÿ0šÓ ÿ ÿ ÿí™0¬•ÃÅ0»»ËÃÿÄ‚0„¸œÒŠÛ‡Ž0ŠÛ؉„¸“
                 # Push dictionary string "black navy dark0 blue medium0 blue blue dark0 green green teal darkÿ deep0 sky0 blue darkÿ medium0 spring0 green lime spring0 green aqua midnight0 blue dodger0 blue light0 sea0 green forest0 green sea0 green darks0 late0 grey lime0 green medium0 sea0 green ÿ royal0 blue steel0 blue darks0 late0 blue mediumÿ ÿ dark0 olive0 green ÿ0 blue corn0 flower0 blue rebecca0 purple medium0 aqua0 marine dim0 grey s0 late0 blue oliveÿ s0 late0 grey lights0 late0 grey mediums0 late0 blue lawn0 green chartre0 use aqua0 marine ÿ purple olive grey sky0 blue light0 sky0 blue blueÿ dark0 red darkm0 agenta sadÿ0 brown dark0 sea0 green light0 green medium0 purple darkÿ pale0 green darkÿ yellow0 green ÿ brown dark0 grey light0 blue green0 yellow paleÿ light0 steel0 blue powder0 blue fire0 brick dark0 golden0 rod mediumÿ ÿ0 brown darkÿ silver mediumÿ0 red indian0 red peru chocolate tan light0 grey thisÿ ÿ golden0 rod paleÿ0 red ÿ gainsÿ ÿ ÿ0 wood lightÿ ÿ dark0 salmon ÿ pale0 golden0 rod light0 coral ÿ alice0 blue honeyÿ ÿ sandy0 brown wheat ÿ white0 smoke mint0 cream ghost0 white salmon antique0 white linen light0 golden0 rod0 yellow old0 lace red m0 agenta deep0 pink orange0 red tomato hot0 pink coral dark0 orange light0 salmon orange light0 pink pink gold p0 eachÿ ÿ0 white ÿ ÿ ÿ0 rose ÿ ÿ ÿ sea0 shell corn0 silk lemonÿ floral0 white snow yellow light0 yellow ivory white"
                 # Where all `ÿ` are automatically filled with the strings on the stack
      0 K       # Remove all "0 " from this string
          #      # Split the colors on spaces

จากนั้นเราจะสร้างรายการความแตกต่างไปข้างหน้า (deltas) ระหว่างแต่ละค่าจำนวนเต็มของสี:

zÑĪåð≠K¯&u+UhĆõ;Éðf.ã₂=нH@O¶ü˜ˆ₂Ɔ¥2Œ’Ktθu1Sнdw΀(#ç¹ü‹U¹³αh+8R∍±æ”ÇKë₆ßõk₃¿θòĀηú¿ζвî!Vs©₂™CÖ.∍JнαθWÀhzαÐé3¾¯|ë¡×°'βâá—P‘Å_uë_§₃P∊%ý/=i]¥5óO₃^E‘[∞₆ć:βU=J€¦†˜X'Žāìd4Ā’δ‹a°∊›ÊÐƶoÂö mвæÁƵ¨¼Yü“à §‚₂¾¤н7Þ9úÂuœ¿®jFSΛ¬ìr½ƒxßULβ7≠°oι—ĀÅýÆgBÐγö™α₆©vÝeEXεò₁Uт3ÈĀ(wº4{ºö쾫Â
åUøò${J#₃O<!øN”;GÑéÈfm ½™×γäJǝõ¥àÐι)λÓ:α–ù?6¦¨·ã™ζÙ4ÍHd›-Iž|ï¦{Ö9ÊàÛ§¥–Σÿ%ć8ùćYáþǝC±;•
                 # Push compressed integer 199435987809271424589508700952987345999804200072375133628254343692108407476588500135573281889031649216370100759626064238727072489415325130552011943231372407222964404763401980843968947657212497212027480199840300219769136432328209307347145119976644138878553798683794751309798787883572249589074597119540397124774131357786254535108429605287982569524294490533853150008626425797260994727581899181000813165364870780739754491720041566206327597753141661846275821649635815830948299823383964329384068145070200611196756567681968774265025511020508722510627341700584849057763591073777679021648285012447092662591008342199952284925672007531443930335828262810273697784303468071652124201899153101970895280421720006686387730894329535589566680885995478455871002071758051626349351150223272343920758114226776399859623393233070539000599481915926111317851112136858026586181791
O褕            # Push compressed integer 1579378
     в           # Convert the larger integer to Base-1579378 as list: [128,11,66,50,25345,7168,128,2827,13428,3794,11209,1126,127,128,1579377,358287,139691,120952,786485,50168,228835,648767,273759,35089,334035,113367,37953,143030,682669,668529,325453,105900,39441,170943,61796,78678,324205,460809,254037,103186,197376,212,44,128,32640,128,478827,15,154856,54302,139,17544,292732,78337,164427,36856,326341,14132,105062,361723,317437,294783,274237,9801,126911,54768,7176,82236,418793,118728,145852,75740,198997,414917,411351,10467,320479,19310,73543,322565,110846,13386,52083,41897,51360,50177,71594,149368,386811,176000,322676,26044,104406,26124,4723,1777,15,238689,80467,5929,25,2565,194821,100211,27493,1295,2540,195348,68122,255,5012,12397,7751,1645,5532,3248,5242,1158,4545,2570,5685,953,1012,1544,15,29,1772,1032,288,1273,750,497,35,10,1030,224,16,15]
               # Undelta this list: [0,128,139,205,255,25600,32768,32896,35723,49151,52945,64154,65280,65407,65535,1644912,2003199,2142890,2263842,3050327,3100495,3329330,3978097,4251856,4286945,4620980,4734347,4772300,4915330,5597999,6266528,6591981,6697881,6737322,6908265,6970061,7048739,7372944,7833753,8087790,8190976,8388352,8388564,8388608,8388736,8421376,8421504,8900331,8900346,9055202,9109504,9109643,9127187,9419919,9498256,9662683,9699539,10025880,10040012,10145074,10506797,10824234,11119017,11393254,11403055,11529966,11584734,11591910,11674146,12092939,12211667,12357519,12433259,12632256,13047173,13458524,13468991,13789470,13808780,13882323,14204888,14315734,14329120,14381203,14423100,14474460,14524637,14596231,14745599,15132410,15308410,15631086,15657130,15761536,15787660,15792383,15794160,15794175,16032864,16113331,16119260,16119285,16121850,16316671,16416882,16444375,16445670,16448210,16643558,16711680,16711935,16716947,16729344,16737095,16738740,16744272,16747520,16752762,16753920,16758465,16761035,16766720,16767673,16768685,16770229,16770244,16770273,16772045,16773077,16773365,16774638,16775388,16775885,16775920,16775930,16776960,16777184,16777200,16777215]

จากนั้นเรากำหนดดัชนีของค่าที่ใกล้เคียงกับอินพุตมากที่สุด (ในแง่ของความแตกต่างที่แน่นอนระหว่างแต่ละสี RGB - และที่นี่ฉันคิดว่าฉันสามารถใช้ builtin .x.. ), กำหนดดัชนีของจำนวนเต็มที่ใกล้เคียงที่สุดนี้ในรายการและใช้ จัดทำดัชนีลงในสตริงสีที่เราสร้างไว้ก่อนหน้านี้:

ε                # Map each integer to:
 I              #  Pair it with the input-integer
   S            #  Push 1000, split to digits: [1,0,0,0]
     ₁β          #  Converted from base-256 to an integer: 16777216
       +         #  Add that to both integers in the pair
        ₁в       #  Convert both integers to base-256 as list (we now have [1,R,G,B])
          €¦     #  Remove the leading 1
            `    #  Push both lists to the stack
             α   #  Get the absolute difference between the lists (at the same indices)
              O  #  Sum these differences
}W               # After the map: get the minimum (without popping the list itself)
  k              # Get the index of this minimum in the list
   è             # And use it to index into the string-color list
                 # (after which the result is output implicitly)

ดูเคล็ดลับ 05AB1E ของฉัน (ทั้งสี่ส่วน)เพื่อทำความเข้าใจว่าทำไม:

  • .•ŒRǝ...Ð:8• คือ "chiffon lavenderblush papayawhip ... cyan turquoise steelblue"
  • “ƒÏª©–°0‡—...‡Ž0ŠÛ؉„¸“ คือ "black navy dark0 blue ... light0 yellow ivory white"
  • •zÑÄ...C±;• คือ 199...791
  • •O褕 คือ 1579378
  • •zÑÄ...C±;••O褕в คือ [128,11,66,...,224,16,15]

1
ที่. เป็นโปรแกรม 05AB1E ที่ยาวที่สุด ฉันเคยเห็น.
connectyourcharger

@connectyourcharger ใช่แล้วที่ยิ่งใหญ่ที่สุดเท่าที่ฉันเคยเขียนมาเต้นโปรแกรมที่ใหญ่ที่สุดของฉันก่อนหน้านี้ที่ 176 ไบต์ .. xD ไม่ใช่เรื่องที่น่าภาคภูมิใจกับความท้าทายในการเล่นกอล์ฟ ;)
Kevin Cruijssen

1
คุณได้รับ upvote ของฉัน :)
connectyourcharger
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.