संयोजन ताला काउंटर


20

दृश्य है:

पीटर अपने दोस्त ब्रायन के साथ जिम में है जब ब्रायन को अचानक अपने इनहेलर की सख्त जरूरत है। ब्रायन फर्श पर गिरने से पहले पीटर को अपने संयोजन लॉक का कोड बताने का प्रबंधन करता है।

जिस क्षण पीटर ब्रायन के लॉकर में जाता है और देखता है कि सूचक किस ओर इशारा कर रहा है, स्टीवी उसे घात लगाता है और उसके चेहरे पर काली मिर्च स्प्रे की एक पूरी कैन छिड़कता है, इस प्रकार पीटर को अंधा कर देता है।

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


चुनौती:

एक फ़ंक्शन / प्रोग्राम लिखें जो दो इनपुट लेता है, ब्रायन से संयोजन और सूचक स्थिति। पीटर को गिनने के लिए संख्याओं का उत्पादन करना होगा।

नियम:

  • संयोजन और संकेतक स्थिति को अलग-अलग तर्क होना चाहिए।
  • इनपुट कमांड प्रॉम्प्ट से या फंक्शन आर्गुमेंट्स के रूप में हो सकता है।
  • आउटपुट को स्क्रीन पर प्रिंट किया जाना चाहिए / अन्यथा प्रदर्शित किया जाना चाहिए (फ़ाइल में नहीं)
  • मान लें कि शुरुआती स्थिति पहले नंबर के समान नहीं है, और संयोजन में सभी तीन नंबर अद्वितीय हैं
  • यह नीचे दी गई तस्वीर में दिखाया गया है, संभव संख्याओं के साथ: 0-39।

निर्देश:

नीचे दिए गए लॉक को खोलने के लिए, आपको निर्देशों के एक सेट का पालन करना होगा:

  1. आपको अपना कोड पता होना चाहिए। मान लें कि यह (38, 16, 22) अभी के लिए है।
  2. डायल को 3 बार दाईं ओर घुमाएं (शुरुआती संख्या को तीन बार पास करें), फिर रुकें जब पहला नंबर (38) संकेतक के साथ संरेखित हो
  3. डायल 1 पूर्ण मोड़ को बाईं ओर मोड़ें, पहले नंबर को पास करें, और जब दूसरा नंबर (16) संकेतक के साथ ऊपर की ओर रुक जाए।
  4. डायल को दाईं ओर मोड़ें और तब रुकें जब तीसरा नंबर (22) सूचक के साथ ऊपर उठे
  5. ताला नीचे खींचो

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

उदाहरण:

Input
38 16 22
33  

Output
33  32  31  30  29  28  27  26  25  24  23  22  21  20  19  18  17  16  15  14  13  12  11  10   9   8   7   6   5   4   3   2   1   0  39  38  37  36  35  34  33  32  31  30  29  28  27  26  25  24  23  22  21  20  19  18  17  16  15  14  13  12  11  10   9   8   7   6   5   4   3   2   1   0  39  38  37  36  35  34  33  32  31  30  29  28  27  26  25  24  23  22  21  20  19  18  17  16  15  14  13  12  11  10   9   8   7   6   5   4   3   2   1   0  39  38  37  36  35  34  33  32  31  30  29  28  27  26  25  24  23  22  21  20  19  18  17  16  15  14  13  12  11  10   9   8   7   6   5   4   3   2   1   0  39  38  39   0   1   2   3   4   5   6   7   8   9  10  11  12  13  14  15  16  17  18  19  20  21  22  23  24  25  26  27  28  29  30  31  32  33  34  35  36  37  38  39   0   1   2   3   4   5   6   7   8   9  10  11  12  13  14  15  16  15  14  13  12  11  10   9   8   7   6   5   4   3   2   1   0  39  38  37  36  35  34  33  32  31  30  29  28  27  26  25  24  23  22

मानक कोड गोल्फ नियम लागू होते हैं।

समाधान जो बाद में पोस्ट किए गए हैं वे अभी भी जीत सकते हैं यदि वे डेनिस के उत्तर से कम हैं।


9
जब तक वह गति को गिन नहीं सकता, इनहेलर व्यर्थ होगा ... इस प्रकार, मेरा कार्यक्रम है:function combination(code){alert("Help! Someone open this locker, the combination is "+code+"!")}
कॉनर ओ'ब्रायन

2
@ C @O'Bʀɪᴇɴ, मान्य बिंदु ... :-) लेकिन: 1. जिस पीटर-व्यक्ति के बारे में हम बात कर रहे हैं वह शेड में सबसे तेज़ उपकरण नहीं है। 2. आप किसी को अपना कोड बताना नहीं चाहेंगे। 3. कौन जानता है, शायद स्टीवी के पास स्प्रे का एक स्पेयर कैन था ..?
स्टेवी ग्रिफिन

1
अरे हाँ। स्टीवी में काली मिर्च स्प्रे की एक अनंत कैन है, है ना? Haha: 3
कॉनर ओ'ब्रायन

क्या हम वैकल्पिक एल्गोरिदम का उपयोग कर सकते हैं जो अभी भी उस लॉक को खोलते हैं?
हस्ताक्षर

1
पीटर को मार्शल आर्ट सीखने की जरूरत है। (और ब्रायन के ढहने पर जिम में कोई कोच क्यों नहीं है? बजट में कटौती?)
kirbyfan64sos

जवाबों:


3

सीजेएम, 52 39 बाइट्स

q~[3X0].{@40,m<1$({(+W%}&:T*T@#)T<)}e_p

CJam दुभाषिया में इसे ऑनलाइन आज़माएं ।

यह काम किस प्रकार करता है

q~      e# Read and evaluate all input. This pushes the initial position
        e# as an integer and the combination as an array.
[3X0]   e# Push [3 1 0]. This encodes the respective numbers of full turns
.{      e# For each number in the combination (N) and the corresponding 
        e# number of full turns (F):
  @     e#   Rotate the initial position on top of the stack.
  40,m< e#   Push [0 ... 39] and rotate it that many units to the left.
        e#   For position P, this pushes [P P+1 ... 39 0 ... P-2 P-1].
  1$(   e#   Copy F and subtract 1.
  {     e#   If the result is non-zero:
    (+  e#     Rotate the array of length 40 one unit to the left.
    W%  e#     Reverse it.
  }&    e#   For position P, this pushes [P P-1 ... 0 39 ... P+2 P+1].
  :T*   e#   Save in T and repeat the array F.
  T@    e#   Push T. Rotate N on top of the stack.
  #)    e#   Find the index of N in T and add 1 to it.
  T<    e#   Keep that many elements from the beginning of T.
  )     e#   Pop the last element of the result (N).
}       e# N is the new initial position.
e_p     e# Flatten the resulting array and print it.

1

ग्रूवी, 189 175 बाइट्स

मान लेता है कि संकेतक को arg0 के रूप में पास किया गया है और कमांड लाइन पर arg1, arg2 और arg3 के रूप में कॉम्बो पास किया गया है ...

i=(args[0]as int)+1
r={i--;i=i<0?39:i;print"$i "}
l={i=++i%40;print"$i "} 
M={j,c->while(i!=j as int){c()}}
120.times{r()}
M(args[1],r)
40.times{l()}
M(args[2],l)
M(args[3],r)

1

पर्ल 5 , 129 + 1 (-ए) = 130 बाइट्स

sub c{$f=pop;do{say$f;$f+=$_[0];$f=$f==-1?39:$f==40?0:$f}while$f-$_[1]}$p=3;c(2*!$p-1,@F[$_,$p]),$p=$_ for 3,3,3,0,0,1,2;say$F[2]

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

कैसे?

sub c{                       # Takes 3 parameters: increment, ending position, starting position
  $f=pop;                    # first place to start counting
  do{
    say$f;                   # output current position
    $f+=$_[0];               # move position
    $f=$f==-1?39:$f==40?0:$f # roll over when passing zero
  }while$f-$_[1]             # stop when ending positition reached
}

# @F gets defined by the -a command line option
# @F holds the combination followed by the starting position

$p=3;                       # starting position is in array index 3, this variable will track the array index of
                            # the current position on the dial

c(2*!$p-1,@F[$_,$p]),$p=$_  # call the movement function (c), setting direction to the left (1) or right (-1) as needed
                            # based on the array index of the previous position (go left when moving from array index 0)
for 3,3,3,0,0,1,2;          # list of the array index of the next position

say$F[2]                    # output final position

1

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

इतनी देर लगती है। लेकिन बहुत कुछ चालू भी हो रहा है।

def f(l,s):
 r=lambda a,b,c=1:range(a,b,c)
 a=r(39,l[0],-1);b=r(l[0],-1,-1)
 c=r(l[1],l[2]-1,-1)if l[2]<l[1]else r(l[1],-1,-1);c.extend(r(39,l[2]-1,-1))
 return'  '.join(`x`for x in sum([r(s,-1,-1),a,b,a,b,a,b,r(39,l[0],-1),r(l[0],40),r(0,40),r(0,l[1]+1),c],[]))

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

मुझे लगता है कि मैं अपनी पिछली पंक्ति में कुछ हिस्सों को बेहतर तरीके से समझ सकता हूं, लेकिन मैं अभी भी गोल्फ को कोड करने के लिए नया हूं और मुझे नहीं पता कि उस सूची संयोजन को थोड़े समय में कैसे निपटा जाए।

इसे सुधारने पर कोई विचार?


0

हास्केल , 135 112 बाइट्स

s!t=[s..39]++[0..mod(t-1)40]
s#t=[s,s-1..0]++[39,38..mod(t+1)40]
(a%b)c s=[s#s,s#s,s#s,s#a,a!a,a!b,b#c,[c]]>>=id

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

लाकोनी की बदौलत 23 बाइट्स बचाए


आप इसके बजाय l s t=एक infix ऑपरेटर घोषित करके घोषणाओं को छोटा कर सकते हैं s#t=। यह दो से अधिक तर्कों के लिए भी काम करता है (a%b)c s=:।
लैकोनी

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