एक बिसात के सभी सफेद या काले वर्गों का आउटपुट


29

परिचय

यह एक शतरंज की बिसात कैसी है।

यहाँ छवि विवरण दर्ज करें

आप देख सकते हैं कि a1एक अंधेरा वर्ग है। हालांकि, b1एक हल्का वर्ग है

काम

चुनौती है, दी गई dark, lightया both, एक विभाजक के साथ सभी अंधेरे , प्रकाश या सभी वर्गों का उत्पादन (जैसे एक व्हाट्सएप या एक नई पंक्ति)। सभी वर्गों का क्रम मायने नहीं रखता

परीक्षण के मामलों

Input: dark
Output: a1 a3 a5 a7 b2 b4 b6 b8 
        c1 c3 c5 c7 d2 d4 d6 d8 
        e1 e3 e5 e7 f2 f4 f6 f8 
        g1 g3 g5 g7 h2 h4 h6 h8

Input: light
Output: a2 a4 a6 a8 b1 b3 b5 b7 
        c2 c4 c6 c8 d1 d3 d5 d7 
        e2 e4 e6 e8 f1 f3 f5 f7 
        g2 g4 g6 g8 h1 h3 h5 h7

Input: both
Output: a1 a2 a3 a4 a5 a6 a7 a8
        b1 b2 b3 b4 b5 b6 b7 b8
        c1 c2 c3 c4 c5 c6 c7 c8
        d1 d2 d3 d4 d5 d6 d7 d8
        e1 e2 e3 e4 e5 e6 e7 e8
        f1 f2 f3 f4 f5 f6 f7 f8
        g1 g2 g3 g4 g5 g6 g7 g8
        h1 h2 h3 h4 h5 h6 h7 h8

नोट: मैंने आउटपुट को पूर्व निर्धारित किया है लेकिन यह आवश्यक नहीं है

यह , इसलिए कम से कम बाइट्स जीत के साथ जमा करना!


तो, कुछ a2a4a6...ठीक होगा?
कॉनर ओ'ब्रायन

@ C @O'Bʀɪᴇɴ इसमें व्हाट्सएप या न्यूलाइन की तरह एक सेपरेटर समाहित करना होता है, ताकि यह अमान्य हो।
अदनान

क्या हम कच्चे 2d मैट्रिक्स का उत्पादन कर सकते हैं? यानी[[a2,a4,a6,a8],[...]...]
कॉनर ओ'ब्रायन

@ C @O'Bʀɪᴇɴ हां, यह अनुमति दी गई है
अदनान

क्या light, darkऔर bothइनपुट के रूप में होना चाहिए Stringया उन्हें किसी भी डेटा प्रकार के माध्यम से दर्शाया जा सकता है?
WKS

जवाबों:


15

पायथ, 22 21 बाइट्स

-1 बाइट @ Sp3000 द्वारा

fn%Chz3%sCMT2sM*<G8S8

फ़ंक्शन के तहत %Chz3, dark1 lightसे 0, और both2 से हैश करते हैं । अगर हम शतरंज के चौकोर के योग की समता को लेते हैं (यानी, a1-> [97, 33]-> (97 + 33)%2= 0, तो डार्क स्क्वेयर 0 पर जाते हैं, और लाइट 1 से यह हमें असमानता से फ़िल्टर करने की अनुमति देता है।

fn%Chz3%sCMT2sM*<G8S8      implicit: z=input
               *           Cartesian product of
                <G8          first 8 letters in G (alphabet)
                   S8        with [1,...,8] implicitly stringified
             sM*<G8S8      ['a1','a2,...,'a8','b1'...'h8']
f          T               Filter that by gives truthy result to lambda T:
        sCMT                   The sum of the ords of the chars in T,
       %    2                  modulo 2
 n                            does not equal
   Chz                          ord of the first char in z,
  %   3                         modulo 3
                            Implicitly print the list.

इसे यहाँ आज़माएँ ।


21:fn%Chz3%sCMT2sM*<G8S8
Sp3000

@ Sp3000 धन्यवाद! यह जानते हुए कि मैं फिट होने के लिए 6 बाइट्स का उपयोग कर रहा था, मुझे अलग-अलग हैश की कोशिश करनी चाहिए थी।
lirtosiast

13

बैश + जीएनयू यूटिलिटीज, 74

printf %s\\n {a..h}{1..9}|sed -n "`sed '/[db]/a1~2p
/t/a2~2p
c/9/d'<<<$1`"

{a..h}{1..9}एक बैश ब्रेस विस्तार है जो 8x8 बोर्ड के लिए सभी निर्देशांक पैदा करता है, साथ ही एक अतिरिक्त कॉलम भी 9। यह महत्वपूर्ण है क्योंकि यह पंक्ति की लंबाई को विषम बनाता है जो चेकर्बोर्ड प्रभाव की अनुमति देता है।

printfबस प्रत्येक समन्वय प्रारूपों, प्रति पंक्ति एक।

निर्मित sed अभिव्यक्ति तब सभी x9निर्देशांक को हटा देती है और फिर स्क्रिप्ट इनपुट के अनुसार या तो विषम या दोनों इनपुट लाइनों को प्रिंट करती है।


11

जावास्क्रिप्ट (स्पाइडरमोनी 30+), 90 85 83 82 बाइट्स

x=>[for(d of"12345678")for(c of"abcdefgh")if(x>'l'^parseInt(c+=d,19)%2|x<'d')c]+''

वर्गों के अल्पविराम से अलग स्ट्रिंग लौटाता है। 99 बाइट्स के लिए संगत संस्करण:

x=>([..."12345678"].map(d=>[..."abcdefgh"].map(c=>c+d).filter(s=>x>'l'^parseInt(s,19)%2|x<'d')))+''

सभी 64 वर्ग नामों की गणना करके काम करता है, फिर उन्हें बेस 19 में पार्स करने के लिए यह देखने के लिए कि क्या वे हल्के या गहरे रंग के हैं।


अच्छा। यह ES7 है
edc65

@ edc65 आह, मुझे याद नहीं आया। मैं इसे अपना दूसरा संस्करण "केवल" ईएस 6 ले रहा हूं।
नील

अब ES6
237 पर

@ edc65 आप कह रहे थे?
नील

4
@ edc65 मुझे नहीं लगता कि हम एक ड्रा के लिए सहमत हो सकते हैं?
नील

10

जावास्क्रिप्ट (ईएस 6), 82 87 98

बेनामी फ़ंक्शन एक स्थान को अलग करता है जो वर्गों के स्ट्रिंग को अलग करता है।

i=>eval("for(o='',v=190;v<322;)v++%19<8&&i<'d'|v&1^i>'l'?o+=v.toString(19)+' ':o")

परीक्षा

f=i=>eval("for(o='',v=190;v<322;)v++%19<8&&i<'d'|v&1^i>'l'?o+=v.toString(19)+' ':o")

// less golfed

q=i=>{
  // loop over the range of number a0 (base 19) to h8 (base 19)
  for(o='',v=190;v<322;) 
  {
    if (v++ %19 < 8) // increment and execute the line below only if second digit in 1..8
      if (i<'d'|v&1^i>'l') // even == light, odd == dark, take both if input is 'both'
        o+=v.toString(19)+' '
  }
  return o
}

document.write('<hr>Both<br>'+f('both'))
document.write('<hr>Light<br>'+f('light'))
document.write('<hr>Dark<br>'+f('dark'))


1
वाह ... यह बस पागल है! मुझे आश्चर्य है कि अगर ES6 के साथ किसी भी छोटे को प्राप्त करना संभव है ...
ETHproductions

@ETHproductions हाँ यह है! मेरे पास 86 तैयार हैं, लेकिन मैं अभी भी कुछ बेहतर करने की कोशिश कर रहा हूं (मेरी - चलती - लक्ष्य नील के साथ 85 ... कोई लानत नहीं 83)
edc65

7

बैच, 192 बाइट्स

@set s=a1 a3 a5 a7
@set t=b2 b4 b6 b8
@if not %1==light call:b
@set s=a2 a4 a6 a8
@set t=b1 b3 b5 b7
@if %1==dark exit/b
:b
@echo %s% %s:a=c% %s:a=e% %s:a=g% %t% %t:b=d% %t:b=f% %t:b=h%

4

पायथ, 48 39 बाइट्स

K*<G8S8Jfq%xGhT2%seT2K?qhz\bK?qhz\lJ-KJ

यहाँ यह कोशिश करो!

अभी भी अन्य पायथ समाधान की तुलना में लंबा है, लेकिन मुझे नहीं लगता कि मैं इसे अपने एल्गोरिथ्म के साथ हरा सकता हूं।

व्याख्या

सबसे पहले हम बोर्ड पर सभी वर्गों की एक सूची तैयार करते हैं और इसे असाइन करते हैं Y। फिर हम इस सूची को फ़िल्टर करते हैं ताकि केवल प्रकाश वर्ग बने रहें और इस सूची को असाइन करें J। उसके बाद हम इनपुट और प्रिंट का मूल्यांकन करते हैं:

  • Y अगर इनपुट था both
  • J अगर इनपुट था light
  • Y-J अगर इनपुट था dark

यह निर्धारित करना कि एक वर्ग हल्का है, निम्नानुसार काम करता है:

  • चार्ट को 1-8 (a-> 1, b-> 2) से संख्या में, परिणाम आदि के 18लिए मैप करें a8
  • जाँच करें कि क्या वे दोनों संख्याएँ विषम हैं या ( x%2 == y%2)
  • यदि वे हैं, तो वर्ग प्रकाश है, अन्यथा इसका अंधेरा

K*<G8S8Jfq%xGhT2%seT2K?qhz\bK?qhz\lJ-KJ  # z=input

 *                                         # Cartesian product of
  <G8                                      # first 8 letters of the alphabet (a-h)
     S8                                    # 1-indexed range (1-8)
K                                          # K holds now all squares
       f             K                     # Filter K 
        q                                  # is equal
         %xGhT2                            # map [a-h] to a number [1-8] and take it modulo 2
               %seT2                       # Take modulo 2 from the row number
                      ?qhz\bK              # If input starts with 'b' print K
                             ?qhz\lJ       # If it starts with 'l' print J
                                    -KJ    # Otherwise print the difference of those 2

ओह गीज़ जो एक लंबे शॉट से मेरा छोटा है।
एडिसन क्रम्प

4

पायथन 2, 73 71 70 बाइट्स

lambda s:[chr(x/8+97)+`x%8+1`for x in range(64)if x+x/8&1^ord(s[0])%3]

मैं अभी भी थोड़ा उलझन में हूं कि क्या कार्य प्रश्न के लिए ठीक है, क्योंकि चुनौती में "विभाजक" का उल्लेख है, लेकिन चूंकि बहुत सारे अन्य फ़ंक्शन सबमिशन हैं जो मैंने किया है।

एरवन के जवाब के समान लेकिन बहुत अधिक पायथन 2-नेस के साथ।

(-2 बाइट्स @xnor की बदौलत)


lol मैं भी बीच का परीक्षण नहीं s=="dark"और s[0]=="d"लेकिन मेरे में मेरी रक्षा के लिए वास्तव में पहली कोशिश मैं इस्तेमाल किया s,*_=sऔर 4cmp
एर्वान

1
मुझे लगता है कि जैसे कम कुछ नहीं होना चाहिए ord(s[_])&_या ord(s[_])/_
xnor

@xnor वास्तव में, साथ है %:) धन्यवाद!
Sp3000

4

PHP, 132 126 120 108 106 बाइट्स

for($s=strtr($argv[1],bdl,210);$c<8;$c++)for($r=0;$r<8;)if((++$r+$c)%2==$s||$s>1)echo"abcdefgh"[$c]."$r ";

यह कोल (4-7) और पंक्तियों (1-8) के माध्यम से लूप करता है और जाँचता है कि दोनों का योग विषम / सम है।

PHP 5.6.4 के साथ परीक्षण किया गया, इसे चलाएं: php -d error_reporting=30709 -r '<CODE>' {dark|light|both}


1
PPCG में आपका स्वागत है! यह एक अच्छा उत्तर है, लेकिन यदि आप स्पष्टीकरण जोड़ते हैं तो आपको अधिक वोट मिलेंगे।
20

मुझे लगता है कि आप की जगह ले सकता $s==2साथ $s-1। यदि $ s = 2, और -1, यह 1 है, जो सत्य है और जारी रहेगा
Martijn

और मुझे लगता है कि यह नोटिस का एक गुच्छा दे $c=0सकता है $c, लेकिन कम से कम अंधेरे के लिए यह ठीक काम करता है
Martijn

धन्यवाद, मार्टिज़न! मैं ब्रेसिज़ निकालना भी भूल गया, -6 बाइट्स अभी के लिए। और मुझे पता नहीं क्यों, लेकिन $s-1काम नहीं करता है, लेकिन यह होना चाहिए। इस महान विचार के लिए धन्यवाद! मैं बाद में डिबग करूंगा।
हत्यारेबसे

मैं इस साइट पर नया हूं, लेकिन अपरिभाषित $cचर के कारण त्रुटि संदेश ? यह थोड़ा अजीब और अमान्य लगता है। या नहीं?
हत्यारे १।

3

विटसी , 90 82 बाइट्स

'`'8\[1+8\:]Yy1-\?8\['1'v8\[vD1+vr?]vX]i'h'-)[88*\[Z?aO]]i'r'-)[?1m]1m
84*\[Z??aO]

पहली पंक्ति का स्पष्टीकरण:

'`'8\[1+8\:]Yy1-\?8\['1'v8\[vD1+vr?]vX]i'h'-)[88*\[Z?aO]]i'r'-)[?1m]i'g'-)[1m]
'`'                     Push ` to the stack. (this is 1 less than a in ASCII)
   8\[     ]            Do the stuff in brackets 8 times.
      1+                Add one on every recursion (this gets a, b, c, d...)
        8\:             Clone the stack 8 times. (This gets 8 of each a, b, c...)
Y                       Remove the current stack.
 y1-\?                  Go one stack to the left (I really need to builtin this)
8\[                 ]   Do the stuff in brackets 8 times.
   '1'                  Push character literal 1 to the stack.
      v                 Save it as a temporary variable.
       8\[       ]      Do the stuff in brackets 8 times.
          v             Push the temporary variable to the stack.
           D            Duplicate the top item of the stack.
            1+          Add one to it (this gives us 1, 2, 3, 4...)
              v         Capture the top item of the stack as a temporary variable.
               r        Reverse the stack.
                ?       Go a stack to the right.
                  vX    Clear the temporary variable slot.
i'h')[          ]       If the last character of the input is 'h', do the stuff in brackets
      88*\[    ]        Do the stuff in brackets 64 times.
           Z            Output everything in the stack as a character.
            ?           Rotate right a stack.
             aO         Output a newline.
i'r')[?1m]              If the penultimate character of the input is 'r', rotate over a 
                        stack, then execute the first index of lines of code.
1m                      Execute the first index of lines of code.

दूसरी पंक्ति की व्याख्या:

84*\[Z??aO]
84*\[     ]   Do the stuff in brackets 32 times.
     Z        Output everything in the stack as a char.
      ??      Rotate two stacks over.
        aO    Output a newline.

'डार्क ’और। दोनों’ के लिए बोनस ट्रेलिंग न्यूलाइन्स होगी। इसके लिए केवल 'डार्क', 'दोनों' या 'लाइट' इनपुट की आवश्यकता होगी।

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


3

PowerShell v3 +, 142 129 बाइट्स

param($a)$d=$a[0]-in('d','b');$l=$a[0]-in('l','b')
97..104|%{$i=[char]$_;1..8|%{if((($q=($_+$i)%2)-eq$l)-or($q+1-eq$d)){"$i$_"}}}

इनपुट लेता है $aऔर दो वेरिएबल्स सेट करता है, अगर हम इनपुट के पहले अक्षर के आधार पर $dसन्दूक या $lआठ वर्गों को आउटपुट करते हैं ।

फिर, हम लूप ओवर करते हैं a-hऔर 1-8उसी चाल का उपयोग करते हैं जैसे कि शतरंज के वर्ग का रंग निर्धारित करने के लिए कि क्या यह एक हल्का या गहरा वर्ग है ( $qपहले परीक्षण में सहायक चर सेट करना ) और उपयुक्त होने पर उस वर्ग को पाइप लाइन में जोड़ें। निष्पादन के बाद, पाइपलाइन पर तत्व प्रति पंक्ति एक आउटपुट होते हैं।

-inऑपरेटर के लिए v3 या नए की आवश्यकता है ।

संपादित करें - 13 बाइट्स को समाप्त करके switchऔर समानता परीक्षण क्रम को बदलकर


3

जोल्फ, 48 बाइट्स

Ζ-ώ~1tΜ fΜZAQ8ΨΖ+ζ|<%ζγwώt8ώ6d|<i'd!x%H2>i'ldbHγ

यह मेरे लिए सभी ग्रीक है ¯ \ _ (greek) _ / is यह edc65 के उत्कृष्ट उत्तर का एक रूपांतरण है।

Ζ-ώ~1t
Ζ        set ζ to 
  ώ~1     100 * 2
 -   t    minus 10 (=190)

ΜZAQ8ΨΖ+ζ|<%ζγwώt8+2t
 ZAQ8                 A zero array of length Q8 (8*8 = 64)
Μ    Ψ                map that
      Ζ+ζ             ζ += 
           %ζγwώt       ζ % (γ = 19)
          <      8      < 8
         |        ώ6  || 12

Μ f■above thing■d|<i'd!x%H2>i'ldbHγ
 _f■above thing■d                    filter the above thing
                 |<i'd!x%H2>i'l      removing all the bad stuff (i<'d'|v%2^i>'l')
Μ                              dbHγ  map each character to base 19

3

पर्ल, 69 + 3 = 72 बाइट्स

$b=/b/;$i=/l/;$_="@{[grep{$i=!$i||$b}map{$l=$_;map{$l.$_}1..8}a..h]}"

साथ चलने के लिए perl -p, जिसके लिए मैंने 3 बाइट्स जोड़े हैं।

कम-गोल्फ वाला संस्करण (थोड़ा अलग है, क्योंकि बेबीकार्ट ऑपरेटर इसे अच्छी तरह से प्रारूपित करना कठिन बनाता है):

$b=/b/;                       # flag for input containing b
$i=/l/;                       # start $i as true if input contains 'l'

@a = grep {
    $i = !$i||$b                # alternate unless $b is true
} map {
    $l = $_;                    # save letter
    map {
        $l.$_                   # join letter and number
    } 1..8                      # generate number sequence
} a..h;                         # generate letter sequence

# golfed version uses babycart operator around array expr to save one byte
$_ = "@a"                       # write array, separated

गोल्फ संस्करण का उपयोग करता है "@{[]}"; टिप्पणी संस्करण का उपयोग करता है @a=...; "@"ताकि टिप्पणी कोड अभी भी चल रहा है।


map$l.$_,1..8-1
चोरोबा

और grep के लिए एक ही चाल: grep$i=!$i||$b,mapफिर से -1
कोरोबा

3

सी ++, 132 बाइट्स

कमांड-लाइन द्वारा इनपुट लेता है। प्रिंट की स्थिति के लिए पॉइंटर / मोडुलो वूडू का उपयोग करता है।

#include<stdio.h>
int main(int i,char**v){for(int n=0;n<64;n++)if((n+(i=n/8))%2-*v[1]%3){putchar(i+97);putchar(n%8+49);putchar(32);}}

मुझे नहीं लगता कि n-लूप आवश्यक है। मुझे लगता है कि छोरों के लिए नेस्टेड है iऔर jकुछ बाइट्स को बंद कर देगा। (i+j)%2दृष्टिकोण वास्तव में चालाक है। मैंने ऐसा नहीं सोचा था।
WKS

मैं सिर्फ इतना है कि आप के (i//8+i%8)%2रूप में एक ही है (i//8+i)%2तो आप कुछ बाइट्स जीत सकते हैं नोटिसj=n%8
Erwan

3

जावा, 143

class H{public static void main(String[]a){for(char
c=96;++c<'i';)for(int
i=0;++i<9;)if((i+c)%2!=a[0].charAt(0)%3)System.out.println(c+""+i);}}

अरे, यह सबसे लंबा जवाब नहीं है :)

इनपुट को कमांड-लाइन तर्क के रूप में लिया जाता है।


3

PHP, 99 82 79 76 74 73 बाइट्स

आईएसओ 8859-1 एन्कोडिंग का उपयोग करता है।

for($z=$argv[1];++$x<72;)$x%9&&$z<c|$z>k^$x&1&&print~ß.chr($x/9+97).$x%9;

इस तरह से चलाएं ( -dकेवल सौंदर्यशास्त्र के लिए जोड़ा गया):

php -d error_reporting=30709 -r 'for($z=$argv[1];++$x<72;)$x%9&&$z<c|$z>k^$x&1&&print~ß.chr($x/9+97).$x%9; echo"\n";' dark

यह इस तरह काम करता है: चर $x1 से 71 तक बढ़ जाता है, संख्या कोशिकाओं के अनुरूप होती है जैसा कि नीचे दिखाया गया है।

r\c 1  2  3  4  5  6  7  8  [invalid column]
A   1  2  3  4  5  6  7  8  9
B  10 11 12 13 14 15 16 17 18
C  19 20 21 22 23 24 25 26 27
D  28 29 30 31 32 33 34 35 36
E  37 38 39 40 41 42 43 44 45
F  46 47 48 49 50 51 52 53 54
G  55 56 57 58 59 60 61 62 63
H  64 65 66 67 68 69 70 71 72

इसलिए, $x modulo 9स्तंभ संख्या $x / 9प्राप्त करता है और पंक्ति संख्या देता है, जिसे मैं एक पत्र का उपयोग करके परिवर्तित करता हूं chr। कोड $z<c|$z>k^$x&1पैदावार trueइनपुट के लिए both( $z<c) और के मामले में lightया darkक्रमशः केवल सम या विषम कोशिकाओं के लिए ( $z>k ^ $x&1)। इस अभिव्यक्ति का परिणाम यह निर्धारित करता है कि सेल निर्देशांक तब मुद्रित किया जाएगा या नहीं। अंत में, यदि $x modulo 9परिणाम होता है 0, तो मैं उस गैर-मौजूद सेल को छोड़ देता हूं।

  • केवल 1 लूप होने से 18 17 बाइट्स (एक बग निश्चित) को सहेजा गया, संख्या को अन्य तरीके के बजाय चार में परिवर्तित करना
  • एक के साथ अंधेरे और प्रकाश के लिए स्थिति को मिलाकर 3 बाइट्स सहेजे गए xor
  • पहले चार के बजाय पूर्ण इनपुट के खिलाफ तुलना करके 3 बाइट्स बचाए
  • सहेजे गए 2 बाइट्स क्योंकि अब किसी चार्ट .125में $x/9+69.9बदलने से पहले सही पंक्ति संख्या प्राप्त करने के लिए अभिव्यक्ति में घटाव करने की आवश्यकता नहीं है
  • एक जगह का उत्पादन करने के लिए उपयोग करके एक बाइट को बचाया

2

जावास्क्रिप्ट ईएस 6, 187 160 159 बाइट्स

मुझे शायद कुछ स्पष्ट रूप से याद आ रहा है। ओह अच्छा। सरणी समतल नहीं होने से मदद मिलती है।

l=s=>(E=[2,4,6,8],O=[1,3,5,7],h=(z=s[0]=="d")?O:E,d=z?E:O,[...h.map(t=>[..."aceg"].map(e=>e+t)),...(d.map(t=>[..."bdfh"].map(e=>e+t))),...(s[0]=="b"?l`d`:[])])

एक 2 डी सरणी देता है।


इसे यहाँ आज़माएँ:


2

रूबी, 85

मुझे लगता है कि इस बारे में छोटे तरीके हैं, लेकिन यह एक प्यारा उपयोग है .upto

gets;'a1'.upto('h8'){|e|puts e if e[/[1-8]/]&&(~/b/||((e.ord%2!=e[1].ord%2)^! ~/l/))}

2

आर, 129 94 बाइट्स

मुझे पता था कि मैं बोर्ड को बेहतर तरीके से तैयार कर सकता हूं :)। अनिवार्य रूप से यह एक उलटा बोर्ड बनाता है, ग्रिड संदर्भों को छानना जहां छाया इनपुट से मेल नहीं खाती है। आउटपुट स्पेस अलग है।

a=which(array(c('light','dark'),c(9,9))[-9,-9]!=scan(,''),T);cat(paste0(letters[a[,1]],a[,2]))

Ungolfed

a=which(                           # Get the indexes of
  array(c('light','dark'),c(9,9))  # an array of light dark
    [-9,-9]                        # except for the ninth row and column
      !=scan(,'')                  # where the value doesn't equal the input
    ,T                             # return array index not vector
  );
cat(paste0(letters[a[,1]],a[,2]))  # using letters for col

परीक्षा

> a=which(array(c('light','dark'),c(9,9))[-9,-9]!=scan(,''),T);cat(paste0(letters[a[,1]],a[,2]))
1: dark
2: 
Read 1 item
a1 c1 e1 g1 b2 d2 f2 h2 a3 c3 e3 g3 b4 d4 f4 h4 a5 c5 e5 g5 b6 d6 f6 h6 a7 c7 e7 g7 b8 d8 f8 h8
> a=which(array(c('light','dark'),c(9,9))[-9,-9]!=scan(,''),T);cat(paste0(letters[a[,1]],a[,2]))
1: light
2: 
Read 1 item
b1 d1 f1 h1 a2 c2 e2 g2 b3 d3 f3 h3 a4 c4 e4 g4 b5 d5 f5 h5 a6 c6 e6 g6 b7 d7 f7 h7 a8 c8 e8 g8
> a=which(array(c('light','dark'),c(9,9))[-9,-9]!=scan(,''),T);cat(paste0(letters[a[,1]],a[,2]))
1: both
2: 
Read 1 item
a1 b1 c1 d1 e1 f1 g1 h1 a2 b2 c2 d2 e2 f2 g2 h2 a3 b3 c3 d3 e3 f3 g3 h3 a4 b4 c4 d4 e4 f4 g4 h4 a5 b5 c5 d5 e5 f5 g5 h5 a6 b6 c6 d6 e6 f6 g6 h6 a7 b7 c7 d7 e7 f7 g7 h7 a8 b8 c8 d8 e8 f8 g8 h8
>

2

ओरेकल SQL 11.2, 192 180 बाइट्स

SELECT CHR(64+x),DECODE(y,0,8,y)FROM(SELECT CEIL(LEVEL/8)x,MOD(LEVEL,8)y FROM DUAL CONNECT BY LEVEL<=64)WHERE(:1='dark'AND MOD(x+y,2)=0)OR(:1='light'AND MOD(x+y,2)=1)OR(:1='both');

संयुक्त राष्ट्र के golfed

WITH v AS
(
  SELECT CEIL(LEVEL/8)x, DECODE(MOD(LEVEL,8),0,8,MOD(LEVEL,8))y  
  FROM DUAL CONNECT BY LEVEL<=64
)
SELECT CHR(64+x),y
FROM   v
WHERE  (:1='dark' AND MOD(x+y,2)=0)OR(:1='light' AND MOD(x+y,2)=1)OR(:1='both');

V दृश्य प्रत्येक वर्ग के निर्देशांक उत्पन्न करता है। यदि निर्देशांक का योग सम है तो वर्ग काला है, अन्यथा यह सफेद है।


2

जंग, 263 259 244 बाइट्स

use std::char;use std::env;fn main(){let n=env::args().nth(1).unwrap();for i in 0..8{for j in 0..8{if n=="both"||(n=="dark"&&(i+j)%2==0)||(n== "light"&&(i+j)%2!=0){println!("{}{}",char::from_u32(i+97).unwrap(),char::from_u32(j+49).unwrap())}}}}

विस्तारित रूप:

fn main() {
    let input = env::args().nth(1).unwrap();
    for i in 0..8{
            for j in 0..8{
                if input == "both"
                || (input == "dark" && (i+j)%2==0)
                || (input == "light" && (i+j)%2!=0){
                    println!("{}{}",char::from_u32(i+97).unwrap(),char::from_u32(j+49).unwrap());
            }
        }
    }
}

1
अपने इनपुट को हार्ड-कोडिंग करने के बजाय, क्या इसे टर्मिनल या कमांड लाइन या फ़ंक्शन पैरामीटर के रूप में पढ़ना संभव नहीं है?
नील

2

MATL , 31 बाइट्स

1)t3\8:t!++w4\~?H\]2#f2Y2!w)wVh

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


यह एक सही वर्ग देने के लिए प्रतीत नहीं होता है। "डार्क" हर अक्षर x के लिए X1, x3, x5, x7 दे रहा है, लेकिन यह 4 कॉलम से मेल खाता है, न कि काले रंग का।
एस्टीमेटर

@Esteemator क्षमा करें, मेरी गलती है। सही किया
लुइस मेंडो

2

सीजेम, 29

qci3%:X;8Ym*{~+2%X-},"a1 "f.+

बस एक त्वरित और गंदा समाधान: पी
इसे ऑनलाइन प्रयास करें

स्पष्टीकरण:

q           read the input
ci          convert to (first) character then to integer
3%          modulo 3; results for d(ark), l(ight) and b(oth) are 1, 0, 2
:X;         store in X and pop
8Ym*        generate all pairs (Y=2) of numbers from 0 to 7
{…},        filter using the condition block
  ~         dump the current pair on the stack
  +2%       calculate the sum modulo 2
  X-        subtract X; if the result is not 0, the pair is kept
"a1 "f.+    vectorized-add "a1 " to each remaining pair
             this means the character 'a' is added to the first number,
             the character '1' is added to the second number,
             and then the space character is appended
            the contents of the stack are automatically printed at the end

2

हास्केल, 133 116 105 100 98 91 बाइट्स

f r=[["abcdefgh"!!x,"12345678"!!y]|x<-l,y<-l,odd(x+y)||r<"l",even(x+y)||r!!0/='d']
l=[0..7]

गोल्फिंग हास्केल में यह मेरा पहला प्रयास है।

माइकल क्लेन की कुछ मदद से, हम इसे 100 वर्णों के नीचे लाने में कामयाब रहे!


1
कैसे के बारे में c>0के लिए c==1और c<1के लिए c==0? दो बाइट बचाता है।
माइकल क्लिन

शानदार, हम इसे 100 के तहत मिल गया! धन्यवाद माइकल।
joeytwiddle

1
आपका स्वागत है। मुझे थोड़ा सा चूसा गया और इसे थोड़ा नीचे रिफ्लेक्ट करके 86 बाइट्स में मिला दिया गया:f r=[[[a,b]|a<-['a'..'h'],b<-['1'..'8']]!!i|i<-[0..63],even i||r<"l",odd i||r!!0/='d']
माइकल क्लेन

1
यह बहुत अच्छा है, एक पुनर्विचार दृष्टिकोण। हालांकि मुझे यह कहने में खेद है कि विषम और यहां तक ​​कि iहमें तिरछी धारियां नहीं दी गई हैं। कुछ इसे i+i`div`8(जैसे x+y) हल करते हैं । अन्य लोग 96 बाइट्स के लिए बाद में केवल परिणामों के साथ शुरुआत करते हैं ['1'..'9']और [0..71]फिर बनाए रखते हैं i`mod`9<8। हालाँकि, हमारे दो दृष्टिकोणों का यह हाइब्रिड 91 बाइट्स में अच्छा करता है:l=[0..7];f r=[["abcdefgh"!!x,"12345678"!!y]|x<-l,y<-l,odd(x+y)||r<"l",even(x+y)||r!!0/='d']
joeytwield

आह, यह अच्छी तरह से अभी भी एक अच्छा सा है
माइकल क्लेन

1

गणितज्ञ 133 बाइट्स

विधि 1 : 108 बाइट्स। यह बोर्ड को एक तालिका के रूप में निर्माण करता है, जिसमें प्रत्येक सेल में लेबल होते हैं, और आवश्यकतानुसार प्रकाश या गहरे विकर्ण या बैंड लौटाते हैं।

Table[Table[{i,j},{i,{h,g,f,e,d,c,b,a}},{j,Range@8}]~Diagonal~k,{k,If[#=="light",-6,-7],7,If[#=="both",1,2]}]&

%["light"]   (*where % repeats the preceding line *)

{{{b, 1}, {a, 2}}, {{d, 1}, {c, 2}, {b, 3}, {a, 4}}, {{f, 1}, {e , 2}, {d, 3}, {c, 4}, {b, 5}, {a, 6}}, {{h, 1}, {g, 2}, {f, 3}, {e , 4}, {d, 5}, {c, 6}, {b, 7}, {a, 8}}, {{h, 3}, {g, 4}, {f, 5}, {e , 6}, {d, 7}, {c, 8}}, {{h, 5}, {g, 6}, {f, 7}, {e, 8}}, {{h, 7}, {छ,,}}}


विधि 2 : 133 बाइट्स। एक सरणी बनाता है और प्रत्येक कक्ष की पंक्ति संख्या + स्तंभ संख्या के योग की सम-विषम प्रकृति के अनुसार चयन करता है।

Position[Array[Boole@OddQ[#+#2] &,{8,8}],Switch[#,"dark",0,"light",1,"both",0|1]]/.
{j_,k_}:>{j/.Thread[Range@8->{a,b,c,d,e,f,g,h}],k}&


1

जेएस, 197 बाइट्स

b=[];d=[];l=[];for(i=1;i<9;i++){for(j=1;j<9;j++){a=String.fromCharCode(96+i*1)+j;b.push(a);if((i+j)%2<1){d.push(a)}else{l.push(a)}}}m=[0,"both",b,"dark",d,"light",l];alert(m[m.indexOf(prompt())+1])

1

पायथन (3.5), 106 100 96 92 बाइट्स

(i+j)%26 बाइट जीतने के लिए मेगाटॉम की चाल का उपयोग करें

f=lambda s:[chr(97+i//8)+str(1+i%8)for i in range(64)if s[0]=='b'or(i//8+i)%2==(s[0]=='l')]

इसे repl.it पर आज़माएँ

परिणाम

>>> f('light')
['a2', 'a4', 'a6', 'a8', 'b1', 'b3', 'b5', 'b7', 'c2', 'c4', 'c6', 'c8', 'd1', 'd3', 'd5', 'd7', 'e2', 'e4', 'e6', 'e8', 'f1', 'f3', 'f5', 'f7', 'g2', 'g4', 'g6', 'g8', 'h1', 'h3', 'h5', 'h7']
>>> f('dark')
['a1', 'a3', 'a5', 'a7', 'b2', 'b4', 'b6', 'b8', 'c1', 'c3', 'c5', 'c7', 'd2', 'd4', 'd6', 'd8', 'e1', 'e3', 'e5', 'e7', 'f2', 'f4', 'f6', 'f8', 'g1', 'g3', 'g5', 'g7', 'h2', 'h4', 'h6', 'h8']
>>> f('both')
['a1', 'a2', 'a3', 'a4', 'a5', 'a6', 'a7', 'a8', 'b1', 'b2', 'b3', 'b4', 'b5', 'b6', 'b7', 'b8', 'c1', 'c2', 'c3', 'c4', 'c5', 'c6', 'c7', 'c8', 'd1', 'd2', 'd3', 'd4', 'd5', 'd6', 'd7', 'd8', 'e1', 'e2', 'e3', 'e4', 'e5', 'e6', 'e7', 'e8', 'f1', 'f2', 'f3', 'f4', 'f5', 'f6', 'f7', 'f8', 'g1', 'g2', 'g3', 'g4', 'g5', 'g6', 'g7', 'g8', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'h7', 'h8']

पुराना वर्जन

f=lambda s:[i for i in[i+j for i in'abcdefgh'for j in'123456780'][s[0]=='l'::2-(s[0]=='b')]if'0'not in i]

1

सी ++, 119 बाइट्स

मेगाटॉम की चाल के आधार पर।

#include <stdio.h>
int main(int n,char**v){for(n=0;n<64;++n){if((n+n/8)%2-**(v+1)%3){printf("%c%c ",n/8+97,n%8+49);}}}

0

सी (जीसीसी) , 112 बाइट्स

f(char*s){for(int m=*s^'d'?*s^'l'?3:2:1,l=64,x;l--;m&1&!x|(m&2&&x)&&printf("%c%d ",l%8+97,l/8+1))x=l%8%2^l/8%2;}

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

यदि एक == 1, तो एक वर्ग हमेशा काला होगा यदि पंक्ति और स्तंभ की "विषमता" समान है, अर्थात दोनों विषम हैं या दोनों समान हैं। सफेद वर्गों के लिए विपरीत सही है, जहां पंक्ति और स्तंभ हमेशा विषमता में भिन्न होंगे।

उसके बाद, यह पंक्ति और स्तंभ छोरों के संयोजन की बात है, साथ ही ऑपरेटर पूर्वता की एक तालिका से परामर्श करना है जब तक कि पर्याप्त स्तर की अक्षमता नहीं हो गई है।

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.