आपके इंटरनेट के लिए बेहतर हेक्स कलर कोड


46

हेक्स ट्रिपल जैसे #ffffff(सफेद) या #3764ef(नीला) अक्सर आरजीबी रंगों को दर्शाने के लिए उपयोग किया जाता है। उनके #बाद छह हेक्साडेसिमल अंक (0-एफ), या कभी-कभी तीन अंक होते हैं जहां वास्तविक रंग प्रत्येक अंक को दोगुना करके प्राप्त किया जाता है। उदाहरण के लिए, #fffहै #ffffffऔर #1a8है #11aa88

अफसोस की बात है, कि तीन अंकों का आशुलिपि अब तक की पेशकश की जाने वाली सबसे छोटी गोल्फ थी ।

एक प्रोग्राम या फ़ंक्शन लिखें जो 1 से 7 अक्षरों की स्ट्रिंग में लेता है:

  • पहला किरदार हमेशा रहेगा #
  • अन्य वर्ण हमेशा हेक्साडेसिमल अंक होंगे 0123456789abcdef:।

इनपुट हेक्स ट्रिपल का एक संक्षिप्त रूप है (या पूर्ण वर्ण यदि 7 वर्ण दिए गए हैं)। आपको एक पूर्ण हेक्स ट्रिपल का उत्पादन करने की आवश्यकता है जो इन पैटर्न के आधार पर इनपुट शॉर्टहैंड का विस्तार करता है:

Input   -> Output
#       -> #000000    (black)
#U      -> #UUUUUU
#UV     -> #UVUVUV
#UVW    -> #UUVVWW    (usual 3-digit shorthand)
#UVWX   -> #UXVXWX
#UVWXY  -> #UVWXYY
#UVWXYZ -> #UVWXYZ    (not shorthand)

से प्रत्येक U, V, W, X, Y, और Zकिसी भी हेक्साडेसिमल अंक हो सकता है। आउटपुट हमेशा 7 वर्ण का होता है।

उदाहरण के लिए:

Input -> Output
# -> #000000
#0 -> #000000
#4 -> #444444
#f -> #ffffff
#a1 -> #a1a1a1
#0f -> #0f0f0f
#99 -> #999999
#1a8 -> #11aa88
#223 -> #222233
#fff -> #ffffff
#1230 -> #102030
#d767 -> #d77767
#bbb5 -> #b5b5b5
#aabbc -> #aabbcc
#00000 -> #000000
#3764e -> #3764ee
#3764ef -> #3764ef
#123456 -> #123456
#f8f8f8 -> #f8f8f8

टिप्पणियाँ

  • इनपुट हमेशा के साथ शुरू होगा #और इसलिए आउटपुट होना चाहिए।

  • आप मान सकते हैं कि सभी इनपुट अक्षर लोअरकेस ( abcdef) या अपरकेस ( ABCDEF) हैं जैसा आप पसंद करते हैं।

  • आउटपुट में पत्र आपके पसंद के अनुसार हो सकते हैं। आप मामलों को भी मिला सकते हैं।

  • अल्फा / पारदर्शिता को यहां नहीं देखा गया है (हालांकि RGBA रंगों के हेक्स संस्करण हैं)।

बाइट्स में सबसे छोटा कोड जीतता है।


11
" अफसोस की बात है, कि तीन अंकों का आशुलिपि था, जो अब तक की पेशकश की जाने वाली सबसे छोटी गोल्फ थी। " - उह, बिल्कुल नहीं । HTML, 0 बाइट्स - यह बॉक्स से बाहर काम करता है
बरगी

11
इसका उल्टा भी एक बड़ी चुनौती होगी
बीटा

9
मैं #UVWXY -> #UVWXYYप्रविष्टि से असंतुष्ट हूं क्योंकि यह ब्लू चैनल के लिए एकल-मूल्य प्रतिनिधित्व की अनुमति देता है, लेकिन लाल और हरे रंग के लिए कोई समान अभिव्यक्ति नहीं है (उदाहरण के लिए अगर मैं चाहता था कि #889071मैं संक्षिप्त नहीं #907188कर सकता , लेकिन हो सकता है ... #90718अन्य) सभी महान काम करते हैं।
ड्रेको 18

3
@ Draco18s मुझे बहुत पसंद है। वह एक और #UVWX -> #UXVXWX। यह एक ऐसा असंगत और मनमाना व्यवहार है, जिस पर विश्वास करना मुश्किल है कि ब्राउज़र की एक जोड़ी नहीं है जो वास्तव में वर्तमान में इसे लागू करते हैं।
xDaizu

1
@xDaizu CSS विनिर्देशन #RGBAऔर है #RRGGBBAA, इसलिए # 1234 को पढ़ा जाना चाहिएrgba(17, 34, 51, 0.25)
tsh

जवाबों:


13

जावास्क्रिप्ट, 86 82 77 बाइट्स

x=>([s,a=0,b=a,c,d,e,f]=x,f?x:e?x+e:[s,a,d||a,c?b:a,d||b,v=c||b,d||v].join``)

बस पता लगाएँ कि पुनरावर्ती को बचाने 4 बाइट्स ...

@Arnauld से विचार 4 बाइट, +1 अधिक बाइट बचाते हैं


([s,a=0,b=a,c,d,e,f]=x)=>f?x:e?x+e:d?s+a+d+b+d+c+d:c?s+a+a+b+b+c+c:s+a+a+a+b+b+b80 बाइट्स के लिए
ल्यूक

@Luke मैं बस मिल गयाReferenceError: x is not defined
TSH

6

जेली , 24 बाइट्स



x2
j0ị$
m0

0
Ḣ;LĿṁ6$$

एक पूरा कार्यक्रम (खाली लाइनें वास्तव में खाली लाइनें हैं)।

इसे ऑनलाइन आज़माएं! या एक परीक्षण सूट देखें*

कैसे?

     - Link 1 (0 bytes), returns its input (e.g. "U" -> "U")
     - Link 2 (0 bytes), returns its input (e.g. "UV" -> "UV")
x2   - Link 3, doubles up (e.g. "UVW" -> "UUVVWW")
j0ị$ - Link 4, joins with final element (e.g. "UVWX" -> "UXVXWXX")
m0   - Link 5, reflects its input (e.g. "UVWXY" -> "UVWXYYXWVU")
     - Link 6 (0 bytes), returns its input (e.g. "UVWXYZ" -> "UVWXYX")
0    - Link 7, returns zero (link 7 is also link 0 since there are 7 links)
Ḣ;LĿṁ6$$ - Main link: string
Ḣ        - head (get the '#')
       $ - last two links as a monad:
   Ŀ     -   call link at index:
  L      -     length
      $  -   last two links as a monad:
    ṁ6   -     mould like 6 (e.g. "UVWXYYXWVU" -> "UVWXYY"
         -                    or  "UV" -> "UVUVUV")
 ;       - concatenate (prepend the '#' again)
         - implicit print

* परीक्षण सूट कार्यक्रम क्या थे के आदेश गमागमन द्वारा बदल किया जा सकता था Main linkऔर Link 7है, जबकि पाद लेख बन गया Main Link। इसके अलावा #प्रोग्राम के रूप में मैन्युअल रूप से प्रतिस्थापित किया जाना था, क्योंकि यह प्रमुख है।


5

CJam, 45  44  42 40 36 35 बाइट्स

q(\0se|_,("6* 3* 2e* )f+ _W=+ "S/=~

इनपुट की लंबाई के आधार पर विभिन्न कोड स्निपेट्स चलाता है।


1
कुछ स्वरूपण <s> नहीं </ s> आवश्यक ....<s></s>
स्टेवेफस्टल


1
अरे! आप समझ गए! मैं वह भूल गया!
स्टेवफेस्टल

4

PHP 7.1, 88 बाइट्स

#<?for(;$i<6;)echo@$argn[_22222232532233423355224462[5*$i+++strlen($argn|aa)*.85]-1]?:0;

PHP 5, 90 88 बाइट्स

#<?for(;$i<6;)echo$argn[_10311001122011333002244012345[6*$i+++strlen($argn|aa)-8]+1]?:0;

मेरे पास कोई आइडिया नहीं है कि आपको यह विचार कैसे आता है लेकिन यह काम करता है। काम _21422112233122444113355123456[6*$i+++strlen($argn|aa)-8]?
जोर्ग ह्यूल्समैन

1
क्या आप बता सकते हैं कि यह कैसे काम करता है?
ब्रायन एच।

यह एक अच्छा है! यह में ऑफसेट भंडार $argnमें 21422112233122444113355123456और चयन strlen के आधार पर सही। aaस्ट्रिंग को कम से कम 2 वर्णों तक पैड करता है। इनपुट पर #कोई आउटपुट नहीं है $argn[1]इसलिए ?:00। यह 0स्ट्रिंग में ऑन के लिए भी काम करता है । मैंने देखा है सबसे अच्छे उत्तरों में से एक! अफसोस की बात है कि यह बहुत अधिक भुगतान नहीं करता है (जोर्ज का जवाब 95 से कम हो गया है)।
क्रिस्टोफ

1
हाहा, यह PHP के स्वचालित स्ट्रिंग्स का सबसे अच्छा दुरुपयोग है जिसे मैंने थोड़ी देर में देखा है। +1
ETHproductions

1
@Christoph दूसरे संस्करण को 7.1 के तहत एक PHP संस्करण और 5.6 से अधिक एक PHP संस्करण की आवश्यकता है, मुझे लगता है कि इसे जोड़ना यह स्पष्ट करना चाहिए
Jörg Hülsermann

3

PHP, 95 93 89 87

<?=strtr(_1.intval([a6n,sot,c8c,lba,vf1,vf2][strlen($argn|aa)-2],33),_134256,$argn.=0);

मूल रूप से @ JörgHülsermann का उत्तर लेकिन बहुत नीचे गोल्फ था इसलिए मैंने इसे अलग जवाब के रूप में पोस्ट करने का फैसला किया। मैं इस जवाब को मेरे और जॉर्ग के सामूहिक प्रयास के रूप में गिनाऊंगा।

-4 bytes thanks to @JörgHülsermann
-1 bytes thanks to @JörgHülsermann's base 33 numbers

3

पायथन 3, 166 162 160 152 बाइट्स

import re
lambda x,d='(.)$',b=r'\1':re.sub(*[('$','0'*6),(d,b*6),('(..)$',b*3),('(\w)',b*2),('.'+'(.)'*4,r'#\1\4\2\4\3\4'),(d,b*2),('','')][len(x)-1],x)

मैं प्रत्येक पैटर्न के लिए रेगेक्स रिप्लेसमेंट ट्यूपल्स की एक सूची बनाता हूं, और फिर इंडेक्स पर टपल को len(x)-1निकालता हूं , अंत *में इसे अलग कर देता हूं ( ) re.sub:

lambda x, d='(.)$', b=r'\1':   # lambda expression, save often used strings
  re.sub(   # regex replacement of:
         *  # expand what follows into arguments, i.e. f(*(1,2)) -> f(1,2)
         [  # list of replacement patterns:
            # 1 character: replace the end with 6 zeroes
            ('$', '0'*6),
            # 2 chars: repeat the last character 6 times
            (d, b*6),
            # 3 chars: repeat the two non-#s 3 times.
            ('(..)$', b*3),
            # 4 chars: replace every non-# with twice itself
            ('(\w)', b*2),
            # 5 chars: has to be somewhat verbose..
            ('.'+'(.)'*4, r'#\1\4\2\4\3\4'), 
            # 6 chars: repeat the last character
            (d, b*2),
            # 7 chars: complete already, replace nothing with nothing
            ('', '')
         ][len(x)-1], # select the element from the list that has the right length
        x)  # replace in argument x

8 बाइट्स को याद करके बचाया r'\1'(धन्यवाद, गैबेर फेकेते)


1
r'\1'नामित पैरामीटर के रूप में उपयोग नहीं करना होगा कुछ बाइट्स को बचाने के लिए?
गबोर फेकेट

1
आपने लिखा है o=r'\1'लेकिन bअपने कोड में उपयोग करें: D
Gábor Fekete

1
@ गैबॉर्फ़ेटे वूप्स: डी
एल 3वीथान

3

जावा 10, 228 227 224 182 बाइट्स

s->{var x="$1$1";int l=s.length();return l>6?s:l>5?s+s.charAt(5):l<2?"#000000":s.replaceAll(l>4?"(.)(.)(.)(.)$":l==3?"([^#]{2})":"([^#])",l>4?"$1$4$2$4$3$4":l>3?x:l>2?x+"$1":x+x+x);}

इसे ऑनलाइन आज़माएं।

स्पष्टीकरण:

s->{                      // Method with String as both parameter and return-type
  var x="$1$1";         //  Create a temp String to repeat a match
  int l=s.length();     //  Length of the String
  return l>6?           //  If the length is 7:
    s                   //   Return the input-String as is
   :l>5?                //  Else-if the length is 6:
    s+s.charAt(5)       //   Return the input-String with the last character repeated
   :l<2?                //  Else-if the length is 1:
    "#000000";          //   Simply return the literal String #000000
   :                    //  Else (the length is 2, 3, 4, or 5):
    s.replaceAll(       //   Return the input-String after a regex replace:
                        //    With as match:
     l>4?               //     If the length is 5:
      "(.)(.)(.)(.)$",  //      Use a match for pattern #(A)(B)(C)(D)
     :l==3?             //     Else-if the length is 3:
      "([^#]{2})"       //      Use a match for pattern #(AB)
     :                  //     Else (the length is 2 or 4):
      "([^#])",         //      Use a match for pattern #(A) or #(A)(B)(C)
                        //    And as replacement: 
     l>4?               //     If the length is 5:
      "$1$4$2$4$3$4"    //      Change #ABCD to #ADBDCD
     :l>3?              //     Else-if the length is 4:
      x                 //      Change #ABC to #AABBCC
     :l>2?              //     Else-if the length is 3:
      x+"$1"            //      Change #AB to #ABABAB
     :                  //     Else (the length is 2):
      x+x+x);}          //      Change #A to #AAAAAA

2

एपीएल (डायलॉग) , 43 बाइट्स

⎕IO←0कई सिस्टम पर डिफ़ॉल्ट की आवश्यकता होती है।

'#',{6⍴(≢⍵)⊃'0' ⍵(2/⍵)(∊⍵,¨⊃⌽⍵)(⍵,⌽⍵)⍵}1↓⍞

इसे ऑनलाइन आज़माएं!

1↓⍞ पहला चरित्र (हैश) छोड़ो

{ निम्नलिखित अनाम फ़ंक्शन लागू करें

(≢⍵)⊃ निम्नलिखित सात में से एक मान लेने के लिए तर्क की लंबाई का उपयोग करें:
  '0' एक शून्य
   तर्क
   तर्क
  2/⍵ दो ( 2प्रत्येक की) ( /तर्क के) ( )
  ∊⍵,¨⊃⌽⍵ चपटा ( ) तर्क ( ) का पालन प्रत्येक ( ) पहले से ( के) उलटा ( ) तर्क ( )
  ⍵,⌽⍵ तर्क ( ) पूर्वसर्गित ( ,) उलट ( ) तर्क ( )
   तर्क

6⍴ उस से तत्वों को दोहराएं जब तक कि छह की लंबाई हासिल न हो जाए

} अनाम फ़ंक्शन का अंत

'#', उस के लिए एक हैश प्रस्तुत करना


2

पायथन 2, 167 165 बाइट्स

-2 बाइट्स ट्रेलज़वीर के लिए धन्यवाद

z=zip
lambda s:'#'+''.join([reduce(lambda x,y:x+y,c)for c in['0'*6,s[1:2]*6,z(s[1:2],s[2:3])*3,z(*z(s[1:2],s[2:3],s[3:4]))*2,z(s[1:4],s[-1]*3),s+s[-1],s][len(s)-1]])

यह स्ट्रिंग की लंबाई के आधार पर स्ट्रिंग्स की एक सूची बनाता है और चुनता है।


1
आप 2 बाइट्स का उपयोग करके बचा सकते हैं z=zip
ट्रेलज़ेविर

2

सैड, 119 (118 बाइट्स + -E)

s/#//
s/^$/0/
s/^.$/&&/
s/^..$/&&&/
s/^(.)(.)(.)$/\1\1\2\2\3\3/
s/^(.)(.)(.)(.)$/\1\4\2\4\3\4/
s/^....(.)$/&\1/
s/^/#/

सीधा पाठ प्रतिस्थापन।


2

PHP, 87 बाइट्स

बेस 35 नंबरों का उपयोग करें

<?=strtr(_2.intval([i4w,qdi,j1y,apg,ruu,ruv][strlen($argn|aa)-2],35),_234156,$argn.=0);

इसे ऑनलाइन आज़माएं!

या बेस 33 नंबरों का उपयोग करें

<?=strtr(_1.intval([a6n,sot,c8c,lba,vf1,vf2][strlen($argn|aa)-2],33),_134256,$argn.=0);

इसे ऑनलाइन आज़माएं!

PHP, 89 बाइट्स

<?=strtr(_1.[11111,21212,12233,42434,23455,23456][strlen($argn|aa)-2],_123456,$argn."0");

इसे ऑनलाइन आज़माएं!

intval(["8kn",gd8,"9ft",wqq,i3j,i3k][strlen($argn|aa)-2],36) 36 बेस का उपयोग करके 3 बाइट्स

PHP, 102 बाइट्स

<?=strtr("01".substr("11111111112121212233424342345523456",5*strlen($argn)-5,5),str_split($argn."0"));

इसे ऑनलाइन आज़माएं!

PHP, 180 बाइट्स

<?=[str_pad("#",7,($l=strlen($p=substr($argn,1)))?$p:0),"#$p[0]$p[0]$p[1]$p[1]$p[2]$p[2]","#$p[0]$p[3]$p[1]$p[3]$p[2]$p[3]","#$p[0]$p[1]$p[2]$p[3]$p[4]$p[4]",$argn][($l>2)*($l-2)];

इसे ऑनलाइन आज़माएं!


1
मैंने इस संस्करण को 95 बाइट्स में नीचे कर दिया, लेकिन मुझे लगा कि यह अलग है इसलिए मैंने इसे स्वयं के उत्तर के रूप में पोस्ट किया । आशा है कि आप इसे पसंद करेंगे :)
क्रिस्टोफ

2
@Christoph इस समय मैं अपने संस्करण के साथ यहाँ हूँ ऑनलाइन कोशिश करो!
जार्ज ह्यूल्समैन

2
बेस 33 एक भयानक विचार है! मैं यहाँ थोड़ी देर बैठा रहा, लेकिन इसके साथ नहीं आया।
क्रिस्टोफ़

1
@ क्रिसटोफ़ यह मेरे पहले संस्करण के आपके गोल्फ के साथ बहुत समान है। आपके दृष्टिकोण के तहत मेरा दृष्टिकोण गोल्फ करना आसान नहीं था
जोर्ज ह्यूल्समैन

1
@Christoph धन्यवाद और आधार 35 नंबर प्रणाली हमारी टीमवर्क में मेरा दृष्टिकोण है
Jörg Hülsermann

2

रेटिना , 90 बाइट्स

#(..)$
#$1$1$1
#(.)(.)(.)$
#$1$1$2$2$3
#(.)(.)(.(.))$
#$1$4$2$4$3
#$
#0
+`#.{0,4}(.)$
$&$1

इसे ऑनलाइन आज़माएं! परीक्षण मामलों में शामिल हैं।

स्पष्टीकरण: पहला अनुवाद दो अंकों को संभालता है, दूसरा एक तीन को, तीसरा एक चार को और चौथा एक शून्य को। हालाँकि, न तो दूसरा और चौथा अनुवाद (अंतिम) अंक दोहराता है, जैसा कि सभी शेष मामलों को कवर करने के लिए वैसे भी अंत में किया जाता है।


2

हास्केल , 130 127 122 118 109 95 बाइट्स ( user1472751 द्वारा )

y a|l<-[last a]=[y"0",y$a++a,a++a++a,do c<-a;[c,c],(:l)=<<init a,a++l,a]!!length a
f(h:r)=h:y r

इसे ऑनलाइन आज़माएं!


पीछे एक शानदार जगह है g
लैकोनी

1
से भी (x:r)!(y:t)=x:y:r!t;e!_=eछोटा है a!b=id=<<[[x,y]|(x,y)<-zip a b]
लकोनी

जैसा कि पहले चार हमेशा #आप कर सकते हैंg(a:t)|l<-last t=a:[ ...
लैकोनी

@ लैकोनी वास्तव में, वे महान सुधार हैं!
15

मुझे एक 95 बाइट समाधान मिला जो आपके समान दृष्टिकोण का उपयोग करता है (महान दिमाग एक जैसे लगते हैं, हुह?)। आप इसका उपयोग कर सकते हैं या मैं एक अलग उत्तर पोस्ट कर सकता हूं।
user1472751 21

2

पॉवर्सशेल, 113 111 बाइट्स

param($s)-join($s+='0'*($s-eq'#'))[0,1+((,1*5),(2,1*2+2),(1,2,2,3,3),(4,2,4,3,4),(2..5+5),(2..6))[$s.Length-2]]

समझाया गया परीक्षण स्क्रिप्ट:

$f = {

param($s)           # parameter string
$s+='0'*($s-eq'#')  # append '0' if $s equal to '#'
$i=(                # get indexes from array
    (,1*5),         # $i = 1,1,1,1,1 if $s.length-2 = 0
    (2,1*2+2),      # $i = 2,1,2,1,2 if $s.length-2 = 1
    (1,2,2,3,3),    # $i = 1,2,2,3,3 if $s.length-2 = 2
    (4,2,4,3,4),    # $i = 4,2,4,3,4 if $s.length-2 = 3
    (2..5+5),       # $i = 2,3,4,5,5 if $s.length-2 = 4
    (2..6)          # $i = 2,3,4,5,6 if $s.length-2 = 5
)[$s.Length-2]
-join$s[0,1+$i]     # join chars from $s by indexes 0, 1 and $i


}

@(
    , ("#", "#000000")
    , ("#0", "#000000")
    , ("#4", "#444444")
    , ("#f", "#ffffff")
    , ("#a1", "#a1a1a1")
    , ("#0f", "#0f0f0f")
    , ("#99", "#999999")
    , ("#1a8", "#11aa88")
    , ("#223", "#222233")
    , ("#fff", "#ffffff")
    , ("#1230", "#102030")
    , ("#d767", "#d77767")
    , ("#bbb5", "#b5b5b5")
    , ("#aabbc", "#aabbcc")
    , ("#00000", "#000000")
    , ("#3764e", "#3764ee")
    , ("#3764ef", "#3764ef")
    , ("#123456", "#123456")
    , ("#f8f8f8", "#f8f8f8")
) |% {
    $s, $e = $_
    $r = &$f $s
    "$($e-eq$r): $r"
}

आउटपुट:

True: #000000
True: #000000
True: #444444
True: #ffffff
True: #a1a1a1
True: #0f0f0f
True: #999999
True: #11aa88
True: #222233
True: #ffffff
True: #102030
True: #d77767
True: #b5b5b5
True: #aabbcc
True: #000000
True: #3764ee
True: #3764ef
True: #123456
True: #f8f8f8

1

जावास्क्रिप्ट (ईएस 6), 96 बाइट्स

s=>'#'+(c=[u,v,w,x,y,z]=s.slice(1)||'0',z?c:y?c+y:(x?u+x+v+x+w+x:w?u+u+v+v+w+w:c.repeat(v?3:6)))


1

पर्ल, 61 बाइट्स

say+(/./g,0)[0,1,(unpack+S7,"g+g+ÜRÉ/Â¥[ [")[y/#//c]=~/./g]

के साथ भागो perl -nE। मान लेता है कि इनपुट बिल्कुल वर्णित है (गलत परिणाम देता है यदि इनपुट में एक अनुगामी न्यूलाइन है)।

स्ट्रिंग "जी + जी + ÜRÉ / ¥ [[[" 7 16-बिट संख्या 11111,11111,21212,12233,42434,23455,23456को 14 लैटिन 1 वर्णों के रूप में एन्कोड करता है । यहाँ स्पष्टता के लिए एक hexdump है:

0000001d: 672b 672b dc52 c92f c2a5 9f5b a05b       g+g+.R./...[.[

मैंने लेटिन -1 स्ट्रिंग को पैक करने के लिए कॉल के साथ बदल दिया (), और मिला perl -nE 'say+(/./g,0)[0,1,(unpack+S7,pack "H*","672b672bdc52c92fc2a59f5ba05b")[y/#//c]=~/./g]':। लेकिन जब मैं "#a" टाइप करता हूं, तो मुझे "# a0a0a0" मिलता है, जो मुझे लगता है कि गलत है। यह "# आस" होना चाहिए। (शायद मैंने पैक में गलती की है () कॉल।)
JL

इस बार मैंने अनपैक () और पैक () कॉल को शाब्दिक शॉर्ट्स के साथ बदल दिया, और मिला perl -nE 'say+(/./g,0)[0,1,(11111,11111,21212,12233,42434,23455,23456)[y/#//c]=~/./g]':। यह अभी भी गलत प्रतीत होता है, क्योंकि "#a" अभी भी "# a0a0a0" ("#aaaaaa" के बजाय) का गलत उत्तर देता है।
JL

आह! मैं यह समझ गया! मुझे -lस्विच का उपयोग करने की आवश्यकता थी (जो "एल" के रूप में "अक्षर एल" में है) -nEस्विच के साथ , इस तरह perl -lnE 'say+(/./g,0)[0,1,(11111,11111,21212,12233,42434,23455,23456)[y/#//c]=~/./g]':। अब यह सही ढंग से काम करता है।
JL

चेतावनी जो कहती है "" (गलत परिणाम देता है यदि इनपुट में अनुगामी नई रेखा है) "" रन के साथ perl -nE"को" रन के साथ perl -lnE" बदलकर" समाप्त किया जा सकता है । ( -lस्विच का हिस्सा आपके लिए अनुगामी न्यूलाइन से छुटकारा दिलाता है।)
जेएल

-Fकमांड लाइन पर उपयोग करने से आप इसे say+(@F,0)[0,1,(unpack+S7,"g+g+ÜRÉ/Â¥[ [")[$#F]=~/./g]कोड में 5 बाइट को सहेजने के लिए बदल सकते हैं ।
Xcali

1

विंडोज बैच, 389 372 362 349 231 बाइट्स

मैंने पूरी तरह से @Neil कोड कॉपी किया है ...

@call:c %s:~1,1% %s:~2,1% %s:~3,1% %s:~4,1% %s:~5,1% %s:~6,1%
@exit/b
:c
@for %%r in (#%1%2%3%4%5%6.%6 #%1%2%3%4%5%5.%5 #%1%4%2%4%3%4.%4 %s%%1%2%3.%3 
%s%%1%2%1%2.%2 %s%%1%1%1%1%1.%1 #000000.0)do @if not %%~xr.==. @echo %%~nr&exit/b

1
% s% को% 1 के साथ बदलने से आपको कुछ बाइट्स बचानी चाहिए।
satibel

2
%s:~3,1%%s:~4,1%से बदला जा सकता है %s:~3,2%। इसके अलावा, मुझे यकीन नहीं है कि यह इनपुट के लिए काम करता है #
नील

2
वैसे, मैंने एक अलग एल्गोरिथ्म की कोशिश की, और यह 243 बाइट्स पर निकला।
नील

1
क्या मुझे पता है कि एल्गोरिथ्म क्या है?
स्टेवेफेस्टल

1
(क्षमा करें, मैं नहीं अपनी टिप्पणी @Neil की कमी के कारण देखा।) वहाँ कुछ बॉयलरप्लेट है, लेकिन ब्याज की दो लाइनें हैं call:c %s:~1,1% %s:~2,1% %s:~3,1% %s:~4,1% %s:~5,1% %s:~6,1%और for %%r in (#%1%2%3%4%5%6.%6 #%1%2%3%4%5%5.%5 #%1%4%2%4%3%4.%4 %s%%1%2%3.%3 %s%%1%2%1%2.%2 %s%%1%1%1%1%1.%1 #000000.0)do if not %%~xr.==. echo %%~nr&exit/b
नील

1

पायथ, 35 बाइट्स

+\#@<R6[J|tQ\0K*6JKKs*R2JjeJJ+JeJ)l

इसे यहाँ ऑनलाइन आज़माएँ , या यहाँ सभी परीक्षण मामलों को सत्यापित करें

+\#@<R6[J|tQ\0K*6JKKs*R2JjeJJ+JeJ)lQ   Implicit: Q=eval(input())
                                       Trailing Q inferred
          tQ                           Remove first char of input
         |  \0                         The above, or "0" if empty
        J                             *Store in J (also yields stored value)
              K*6J                    *Repeat J 6 times, store in K
                  KK                  *2 more copies of the above
                    s*R2J             *Duplicate each char of J in place
                         jeJJ         *Join chars of J on last char of J
                             +JeJ     *Append last char of J to J
       [                         )     Wrap the 5 starred results in an array
    <R6                                Trim each to length 6
   @                              lQ   Choose result at index of length of input
                                       (Modular indexing, so length 7 selects 0th element)
+\#                                    Prepend #, implicit print

1

पायथन 2 , 99 बाइट्स

def a(s):s=s[1:]or'0';l=len(s);print('#'+(l/4*s[-1]).join(i+i*(l==3)for i in(l<5)*6*s)+s+s[-1])[:7]

इसे ऑनलाइन आज़माएं!


अच्छी पहली पोस्ट। एक तरफ के रूप में, यह ऑनलाइन कोशिश करो! एक वैकल्पिक लेकिन अनुशंसित साइट है जो आपके उत्तर में शामिल करने के लिए कोड चलाता है। यह CG & CC पोस्ट जेनरेट कर सकता है और बूट करने के लिए एक सटीक बाइट काउंट देता है।
विस्कह

बहुत अच्छा, धन्यवाद!
जितेश

0

पायथन 2 - 179 बाइट्स

n=raw_input()                                #prompts for string
t=len(n)                                     #the length of the string is stored to 't'
if t==1:n+="0"*6                             #if t is only one char long, it needs to be black, so n is assigned 6 zeroes
if t==2:n+=n[1]*5                            #if t is two chars long, it adds the last character times 5 at the end
if t==3:n+=n[1:3]*2                          #if t is 3 chars, it multiplies the last two digits times 3
if t==4:n="#"+n[1]*2+n[2]*2+n[3]*2           #if t is 4 chars, it multiplies each char by two
if t==5:n=n[:2]+n[4]+n[2]+n[4]+n[3]+n[4]     #if t is 5 chars, it makes it work
if t==6:n+=n[t-1]                            #if t is 6 chars, it adds the last character to the end
print n                                      #it prints out n

क्या कोई मुझे कुछ बाइट्स बचाने में मदद कर सकता है? अगर सभी के बयानों से ऐसा लगता है कि उन्हें कुछ छोटा किया जा सकता है, तो मुझे नहीं पता।


1
प्रत्येक स्निपेट को एक सूची में डालने और अनुक्रमित करने का प्रयास करें। इसके अलावा, पायथन 3 पर स्विच करने से सबसे अधिक संभावना बाइट्स की बचत होगी और list[len(list)-x]यह उसी के समान है list[-x]
कैलक्यूलेटरफलाइन

आप कुछ बाइट्स बाहर निचोड़ चाहते हैं, परिवर्तित करने पर विचार if t==1:करने के लिए if t<2:(और if t==2:करने के लिए if t<3:, आदि)। यह सुनिश्चित करने के लिए कम पठनीय है, लेकिन अधिक कोड-गोल्फ-सक्षम है!
JL

0

TXR लिस्प: 171 बाइट्स

इंडेंट:

(do let ((s (cdr @1)))
  (caseql (length s)
    (0 "#000000") 
    (1 `#@s@s@s@s@s@s`)
    (2 `#@s@s@s`)
    (3 `#@[mappend list s s]`)
    (4 `#@[s 0]@[s 3]@[s 1]@[s 3]@[s 2]@[s 3]`)
    (5 `#@s@[s 4]`)
    (6 `#@s`))))

यह एक अनाम फ़ंक्शन है: doमैक्रो एक (lambda ...)प्रपत्र बनाता है।

यह मुहावरेदार कोडिंग शैली है, जो उत्पादन के लिए उपयुक्त है; एकमात्र गोल्फिंग व्हॉट्सएप स्क्वैशिंग है:

(do let((s(cdr @1)))(caseql(length s)(0"#000000")(1`#@s@s@s@s@s@s`)(2`#@s@s@s`)(3`#@[mappend list s s]`)(4`#@[s 0]@[s 3]@[s 1]@[s 3]@[s 2]@[s 3]`)(5`#@s@[s 4]`)(6`#@s`))))

0

ब्रिंगोल्फ , 95 बाइट्स

l1-.1e$_!&@4>[!@]|.2e$_!&@!@2!@2|.3e$_<@V2[R<!@!@v]|.4e$_<@VRM&,2>[@v!@R]|.5e$_<@!&@@|.6e$_&@|;

इसे ऑनलाइन आज़माएं!

यह प्रभावी रूप #से इनपुट के बाद वर्णों की मात्रा पर स्विच-केस के बराबर ब्रिंगोल्फ है ।

व्याख्या

सामान जो हमेशा चलता है:

l1-.1  Implicit input to stack
l      Push length of stack
 1-    Decrement last item in stack
   .   Duplicate last item in stack
    1  Push 1

अगर #X :

e$_!&@4>[!@]|
e              If last 2 items (input length - 1 and 1) are equal..
 $_            ..Pop last item silently
   !&@         ..Print entire stack as chars without popping
      4>       ..Push 4 and move it to start of stack
        [..]   ..While loop, decrements first item in stack when it reaches ]
               ..If first item in stack is 0 when reaching ], exit loop
               ..This loop will run 5 times
         !@    ....Print last char without popping
            |  endif

अगर #XX

यह थोड़ा गोल्फ हो सकता है, जब मैं घर पहुंचता हूं तो मैं इसे देख सकता हूं

.2e$_!&@!@2!@2|
.2               Duplicate last item and push 2
  e              If last 2 items (input length - 1 and 2) are equal..
   $_            ..Pop last item silently
     !&@         ..Print entire stack as chars without popping
        !@2      ..Print last 2 items as chars without popping
           !@2   ..Print last 2 items as chars without popping
              |  Endif

अगर #XXX

.3e$_<@V2[R<!@!@v]|
.3                   Duplicate last item and push 3
  e                  If last 2 items (input length - 1 and 3) are equal..
   $_                ..Pop last item silently
     <@              ..Move first item in stack to the end, then pop and print
       V2            ..Create new stack and push 2 to it
         [.......]   ..While loop, see above for explanation
          R<         ....Switch to stack1 and move first item to end of stack
            !@!@     ....Print last item on stack twice without popping
                v    ....Move to stack2 for loop counting
                  |  Endif

तुम्हें नया तरीका मिल गया है




0

05AB1E , 24 बाइट्स

ćU©0®Ð€D®S¤ý®¤«)JIgè6∍Xì

इसे ऑनलाइन आज़माएं या सभी परीक्षण मामलों को सत्यापित करें

स्पष्टीकरण:

ć           # Extract the head of the (implicit) input-string;
            # pop and push remainder and head
 U          # Pop and store the head in variable `X`
  ©         # Store the remainder in variable `®` (without popping)
  0         # Push a 0
  ®Ð        # Push `®` three times
    D      # Duplicate each character in the last copy (which becomes a character-list)
  ®S        # Push variable `®` again, converted to a character-list
    ¤       # Get its last character (without popping the list itself)
     ý      # Join the list by this character
  ®         # Push variable `®` once again
   ¤        # Get its last character (without popping the string itself)
    «       # Append it to the string
  )         # Wrap all values into a list
   J        # Join the inner list from `€D` together to a list,
            # or in case of input `#`, join everything together to string "0"
            #  i.e. "#" → (["","0","","","",""] → ) "0"
            #  i.e. "#4" → ["4","0","4","4","44","4","44"]
            #  i.e. "#a1" → ["a1","0","a1","a1","aa11","a11","a11"]
            #  i.e. "#1a8" → ["1a8","0","1a8","1a8","11aa88","18a88","1a88"]
            #  i.e. "#abcd" → ["abcd","0","abcd","abcd","aabbccdd","adbdcdd","abcdd"]
            #  i.e. "#3764e" → ["3764e","0","3764e","3764e","33776644ee","3e7e6e4ee","3764ee"]
            #  i.e. #123456 → ["123456","0","123456","123456","112233445566","16263646566","1234566"]
    Ig      # Push the length of the input
      è     # Index (0-based) this into the list (with automatic wraparound for length=7)
       6   # Extend/shorten the string to length 6
         Xì # And prepend variable `X` (the "#")
            # (after which the result is output implicitly)
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.