टार्ज़न का ओलंपिक विने-स्विंगिंग रूटीन


32

ओलंपिक बेल-झूले मानक पेड़ों में अपनी दिनचर्या का प्रदर्शन करते हैं। विशेष रूप से, स्टैण्डर्ड ट्री nमें प्रत्येक नॉनज़ेरो वर्टेक्स को उसके नीचे के शीर्ष से जोड़ने वाले किनारों के 0माध्यम से ऊपर की ओर कोने होते हैं । इसलिए, उदाहरण के लिए, स्टैंडर्ड ट्री 5 इस तरह दिखता है:n-1an % a

3
|
2   4
 \ /
  1
  |
  0

क्योंकि शेष जब 5 को 3 से विभाजित किया जाता है, तो शेष 5 को 2 से विभाजित किया जाता है या 4 को 1 से विभाजित किया जाता है, और जब 5 को 1 से विभाजित किया जाता है, तो शेष 0 होता है।

इस साल, टार्ज़न अपने सोने का बचाव नई दिनचर्या के साथ कर रहा है, जिनमें से प्रत्येक शीर्ष पर शुरू होता है, घूमता है n - 1, शीर्ष पर जाता है n - 2, फिर भी n - 3, आदि तक जारी रहता है , जब तक कि वह अंत में शीर्ष पर नहीं जाता 0

एक रूटीन के लिए स्कोर प्रत्येक स्विंग (डिसकाउंट सहित) के लिए स्कोर का योग है, और स्विंग के लिए स्कोर इसकी शुरुआत और अंत बिंदुओं के बीच पेड़ के बीच की दूरी है। इस प्रकार, स्टैंडर्ड ट्री 5 पर टार्ज़न की दिनचर्या का स्कोर 6 है:

  • से एक स्विंग 4करने के लिए 3स्कोर तीन अंक (नीचे, ऊपर, ऊपर),
  • से एक स्विंग 3करने के लिए 2प्राप्तांक एक ही अंक (नीचे),
  • से एक स्विंग 2करने के लिए 1प्राप्तांक एक ही अंक (नीचे), और
  • एक अंक (एक डाउन) 1से 0स्कोर में गिरावट।

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

 1 ->  0
 2 ->  1
 3 ->  2
 4 ->  6
 5 ->  6
 6 -> 12
 7 -> 12
 8 -> 18
 9 -> 22
10 -> 32
11 -> 24
12 -> 34
13 -> 34
14 -> 36
15 -> 44
16 -> 58
17 -> 50
18 -> 64
19 -> 60
20 -> 66
21 -> 78
22 -> 88
23 -> 68
24 -> 82

लिए नियम और कोड स्कोरिंग हमेशा की तरह हैं ।


9
मैं इस अनुक्रम को OEIS में खोजने में विफल रहा। अच्छा प्रश्न।
लीकी नून

8
बहुत बढ़िया युक्ति!
xnor

1
@LeakyNun इसे हालांकि जोड़ा जाना चाहिए। यह एक बहुत ही मूल अनुक्रम है! (बैकस्टोरी के बिना भी)
DanTheMan

जवाबों:


12

सी, 98 97 बाइट्स

F(i){int c[i],t=i-2,n=0,p;for(;++n<i;)for(p=c[n]=n;p=i%p;c[p]=n)t+=c[p]<n-1;return i>2?t*2:i-1;}

यह निम्न सूत्र के साथ प्रत्येक जोड़ी के बीच की दूरी की गणना करता है:

  • रूट ए से नोड ए तक की दूरी जोड़ें
  • रूट से नोड बी तक दूरी जोड़ें
  • ए और बी के आम जड़ की लंबाई 2 * घटाएँ

इसका यह फायदा है कि जब सभी जोड़ों के लिए आवेदन किया जाता है, तो यह उसी तरह होता है:

  • 2 * जड़ से प्रत्येक नोड के लिए दूरी जोड़ें
  • प्रत्येक नोड जोड़ी की आम जड़ की लंबाई 2 * घटाएँ
  • पहले नोड से रूट की दूरी घटाएं
  • जड़ से अंतिम नोड तक की दूरी घटाएं

तर्क को सरल बनाने के लिए, हम मानते हैं कि हम प्रश्न 1 के रूप में n-1 से 0 के बजाय नोड 0 से नोड n-1 तक जा रहे हैं। रूट नोड से नोड 0 तक की दूरी स्पष्ट रूप से 0 (वे समान हैं)। और हम देख सकते हैं कि (अधिकांश) पेड़ों के लिए, अंतिम नोड से जड़ तक की दूरी 2 है:

                    n+1 % n = 1  for all n > 1
and:                  n % 1 = 0  for all n >= 0
therefore:  n % (n % (n-1)) = 0  for all n > 2

इसका मतलब है कि हमारे पास कुछ विशेष मामले हैं (n <2) लेकिन हम उन लोगों के लिए आसानी से पर्याप्त हो सकते हैं।

टूट - फूट:

F(i){                               // Types default to int
    int c[i],                       // Buffer for storing paths
        t=i-2,                      // Running total score
        n=0,                        // Loop index
        p;                          // Inner loop variable
    for(;++n<i;)                    // Loop through all node pairs (n-1, n)
        for(p=c[n]=n;p=i%p;c[p]=n)  //  Recurse from current node (n) to root
            t+=c[p]<n-1;            //   Increase total unless this is a common
                                    //   node with the previous path
    return i>2?   :i-1;             // Account for special cases at 1 and 2
               t*2                  // For non-special cases, multiply total by 2
}

धन्यवाद @ बफ़र्स 1 बाइट के लिए बचाया


बोनस: पेड़!

मैंने यह देखने के लिए एक त्वरित और गंदा कार्यक्रम लिखा कि ये पेड़ क्या दिखते हैं। यहाँ कुछ परिणाम हैं:

6:

5 4  
| |  
1 2 3
 \|/ 
  0  

8:

  5      
  |      
7 3   6  
|  \ /   
1   2   4
'--\|/--'
    0    

13:

   08              
    |              
11 05   10 09 07   
 |   \ /    |  |   
02   03    04 06 12
 '-----\  /---'--' 
        01         
         |         
        00         

19:

   12                       
    |                       
   07   14                  
     \ /                    
     05    15 11            
       \  /    |            
17      04    08 16 13 10   
 |       '-\  /--'   |  |   
02          03      06 09 18
 '---------\ |/-----'--'--' 
            01              
             |              
            00              

49:

                         31                                                    
                          |                                                    
           30            18   36                                               
            |              \ /                                                 
           19   38 27      13    39 29    32                                   
             \ /    |        \  /    |     |                                   
   26        11    22 44      10    20 40 17   34                              
    |         '-\  /--'        '-\  /--'    \ /                                
47 23   46       05               09        15    45 43 41 37 33 25    35 28   
 |   \ /          '--------------\ |/-------'-----'   |  |  |  |  |     |  |   
02   03                           04                 06 08 12 16 24 48 14 21 42
 '----'--------------------------\ |/----------------'--'--'--'--'--'    \ |/  
                                  01                                      07   
                                   '-----------------\  /-----------------'    
                                                      00                       

रिटर्न स्टेटमेंट में कुछ सतही कोष्ठक हैं।
feersum

@ फेरेसम डोह! वे हमेशा से बहुत अधिक नहीं थे, लेकिन फिर मैंने विशेष केस हैंडलिंग को बदल दिया। धन्यवाद!
डेव

3
विज़ुअलाइज़ेशन प्यार!
एडवर्ड

7

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

def f(a,i=1):h=lambda n:n and{n}|h(a%n)or{0};return i<a and len(h(i)^h(i-1))+f(a,i+1)

7

पर्ल, 65 59 55 54 बाइट्स

के लिए +2 शामिल है -ap

STDIN पर पेड़ के आकार के साथ दौड़ें:

for i in `seq 24`; do echo -n "$i: "; vines.pl <<< $i; echo; done

vines.pl:

#!/usr/bin/perl -ap
$_=map{${"-@F"%$_}|=$_=$$_|$"x$p++.1;/.\b/g}1-$_..-1

व्याख्या

यदि आप पेड़ को फिर से लिखते हैं

3
|
2   4
 \ /
  1
  |
  0

जहां प्रत्येक नोड में अपने सभी पूर्वजों और स्वयं का सेट होता है:

 {3}
  |
{2,3}   {4}
   \    /
    \  /
  {1,2,3,4}
      |
 {0,1,2,3,4}

फिर हम वर्णन कर सकते हैं जैसे कि सभी नोड्स 4 से 3 तक का रास्ता:

  • सभी नोड्स जिनमें 3 नहीं हैं, लेकिन 4 (3 से नीचे जा रहे हैं)
  • सभी नोड्स जिनमें 4 नहीं हैं, लेकिन 3 (4 से नीचे जा रहे हैं)
  • उच्चतम नोड जिसमें 3 और 4 दोनों शामिल हैं (सम्मिलित)

किनारों की संख्या नोड्स की संख्या से एक कम है इसलिए हम उपयोग कर सकते हैं कि जुड़ने के बिंदु को अनदेखा करें, इसलिए 4 से 3 तक के मार्ग पर किनारों की संख्या 3 है क्योंकि:

  • नोड्स की संख्या जिसमें 3 नहीं, बल्कि 4: 2 नोड होते हैं
  • नोड्स की संख्या जिसमें 4 नहीं, बल्कि 3: 1 नोड है

ध्यान दें कि यह एक ऐसे मार्ग के लिए भी काम करता है जो सीधे अपने लक्ष्य पर जाता है, उदाहरण के लिए 3 से 2 तक के मार्ग के लिए किनारों की संख्या 1 है:

  • नोड्स की संख्या जिसमें 2 नहीं, बल्कि 3: 0 नोड होते हैं
  • नोड्स की संख्या जिसमें 3 नहीं, बल्कि 2: 1 नोड है

हम फिर इन सभी संयोजनों पर योग कर सकते हैं।

यदि आप इसके बजाय सिर्फ एक नोड को देखते हैं, तो नोड 2 पूर्वज सेट के साथ {2,3}। यह नोड पथ को संसाधित करते समय एक बार योगदान करने वाला है 2 to 1क्योंकि इसमें 2 नहीं बल्कि 1 है। यह पथ के लिए कुछ भी योगदान नहीं करेगा 3 to 2क्योंकि इसमें 2 और 3 दोनों हैं, लेकिन यह एक बार योगदान देगा जब पथ को संसाधित करना होगा 4 to 3क्योंकि इसमें 3 नहीं है लेकिन नहीं 4. सामान्य रूप से नोड के पूर्वज सेट में एक संख्या प्रत्येक पड़ोसी (उच्चतर के निचले हिस्से) के लिए एक का योगदान करेगी जो सेट में नहीं है। अधिकतम तत्व को छोड़कर (इस मामले में 4) जो केवल कम पड़ोसी 3 के लिए योगदान देता है क्योंकि कोई रास्ता नहीं है5 to 4। Simular 0 एक तरफा है, लेकिन चूंकि 0 हमेशा पेड़ की जड़ में होता है और इसमें सभी संख्याएँ होती हैं (यह अंतिम जुड़ाव है और हम जुड़ते नहीं हैं) 0 से कोई योगदान कभी नहीं होता है इसलिए नोड 0 को छोड़ना सबसे आसान है। पूरी तरह से।

इसलिए हम प्रत्येक नोड के लिए पूर्वज सेट को देखते हुए, सभी नोड्स पर योगदान और योग की गणना करके समस्या को हल कर सकते हैं।

पड़ोसियों को आसानी से संसाधित करने के लिए, मैं पूर्वजों के रिक्त स्थान की एक स्ट्रिंग के रूप में प्रतिनिधित्व करने जा रहा हूं और जहां स्थिति 1 पर प्रत्येक 1 का प्रतिनिधित्व करता है कि n-1-p एक पूर्वज है। इसलिए उदाहरण के लिए 1 के हमारे मामले में n=50 से संकेत मिलता है कि 4 पूर्वज है। मैं अनुगामी स्थानों को छोड़ दूंगा। तो मेरे द्वारा बनाए गए पेड़ का वास्तविक प्रतिनिधित्व होगा:

" 1"
  |
" 11"   "1"
   \    /
    \  /
   "1111"

ध्यान दें कि मैंने नोड 0 छोड़ दिया है जिसका प्रतिनिधित्व "11111"इसलिए किया जाएगा क्योंकि मैं नोड 0 को अनदेखा करने जा रहा हूं (यह कभी योगदान नहीं करता है)।

अब 1 के अनुक्रम के अंत में बिना निचले पड़ोसी वाले पूर्वजों का प्रतिनिधित्व किया जाता है। अब किसी भी उच्च पड़ोसी वाले पूर्वजों को 1 के अनुक्रम के प्रारंभ द्वारा प्रस्तुत नहीं किया जाता है, लेकिन हमें एक स्ट्रिंग की शुरुआत में अनुक्रम की किसी भी शुरुआत को अनदेखा करना चाहिए क्योंकि यह उस पथ का प्रतिनिधित्व करता है 5 to 4जो मौजूद नहीं है। यह संयोजन रेगेक्स द्वारा बिल्कुल मेल खाता है /.\b/

पूर्वज तारों का निर्माण क्रम में सभी नोड्स को संसाधित करके किया जाता है n-1 .. 1और वहां नोड के लिए स्थिति में 1 सेट किया जाता है और वंश में एक "या" कर रहा है।

इस कार्यक्रम को समझने के लिए काफी आसान है:

-ap                                                  read STDIN into $_ and @F

   map{                                    }1-$_..-1 Process from n-1 to 1,
                                                     but use the negative
                                                     values so we can use a
                                                     perl sequence.
                                                     I will keep the current
                                                     ancestor for node $i in
                                                     global ${-$i} (another
                                                     reason to use negative
                                                     values since $1, $2 etc.
                                                     are read-only
                       $$_|$"x$p++.1                 "Or" the current node
                                                     position into its ancestor
                                                     accumulator
                    $_=                              Assign the ancestor string
                                                     to $_. This will overwrite
                                                     the current counter value
                                                     but that has no influence
                                                     on the following counter
                                                     values
       ${"-@F"%$_}|=                                 Merge the current node
                                                     ancestor string into the
                                                     successor
                                                     Notice that because this
                                                     is an |= the index
                                                     calculation was done
                                                     before the assignment
                                                     to $_ so $_ is still -i.
                                                     -n % -i = - (n % i), so
                                                     this is indeed the proper
                                                     index
                                     /.\b/g          As explained above this
                                                     gives the list of missing
                                                     higher and lower neighbours
                                                     but skips the start
$_=                                                  A map in scalar context
                                                     counts the number of
                                                     elements, so this assigns
                                                     the grand total to $_.
                                                     The -p implicitly prints

सूचना की जगह है कि /.\b/द्वारा /\b/हल करती है इस समस्या से गोल यात्रा संस्करण है जहाँ टार्जन पथ लेता है0 to n-1

पूर्वज के तार कैसे दिखते हैं, इसके कुछ उदाहरण (क्रम में दिए गए हैं n-1 .. 1):

n=23:
1
 1
  1
   1
    1
     1
      1
       1
        1
         1
          1
          11
         1  1
        1    1
       1      1
      11      11
     1          1
    11  1    1  11
   1              1
  1111  11  11  1111
 111111111  111111111
1111111111111111111111
edges=68

n=24:
1
 1
  1
   1
    1
     1
      1
       1
        1
         1
          1
           1
          1 1
         1   1
        1     1
       1       1
      1         1
     1  1     1  1
    1             1
   11    1   1    11
  1   1         1   1
 1        1 1        1
1                     1
edges=82

व्हाट्स, माफ करना, मुझे नहीं पता था कि आपका संपादन केवल कुछ सेकंड का था। वैसे भी, बहुत साफ दृष्टिकोण और स्पष्टीकरण!
FryAmTheEggman

@FryAmTheEggman कोई समस्या नहीं, हम ठीक उसी लेआउट समस्या को ठीक कर रहे थे। वैसे भी, हाँ, मैं इस कार्यक्रम में सभी टुकड़ों के एक साथ आने से काफी खुश हूँ। मुझे वर्तमान में कोई वसा नहीं दिख रहा है ..
टन हास्पेल

3

गणितज्ञ, 113 103 102 बाइट्स

(r=Range[a=#-1];Length@Flatten[FindShortestPath[Graph[Thread[r<->Mod[a+1,r]]],#,#2]&@@{#,#-1}&/@r]-a)&

-10 बाइट्स @ थर्सम को धन्यवाद; -1 बाइट थैंक्स टू @ मर्टिनएंडर

निम्नलिखित बहुत जल्दी है (लेकिन अब, दुर्भाग्य से, 158 बाइट्स पर ):

(a=#;If[a<4,Part[-{1,1,1,-6},a],If[EvenQ@a,-2,1]]+a+4Total[Length@Complement[#,#2]&@@#&/@Partition[NestWhileList[Mod[a,#]&,#,#!=0&]&/@Range@Floor[a/2],2,1]])&

मेरा मानना ​​है कि आप उपयोग किए बिना चीजों को असाइन कर सकते हैं With। यह भी ऐसा लगता है कि हर बार Rangeइस्तेमाल किया जाता है, aयह तर्क है, ताकि बाहर फैक्टर किया जा सके।
19

1
r=Range[a=#-1]एक बाइट बचाता है।
मार्टिन एंडर

2

जे, 37 बाइट्स

[:+/2(-.+&#-.~)/\|:@(]|~^:(<@>:@[)i.)

उपयोग:

   f=.[:+/2(-.+&#-.~)/\|:@(]|~^:(<@>:@[)i.)
   f 10
32
   f every 1+i.20
0 1 2 6 6 12 12 18 22 32 24 34 34 36 44 58 50 64 60 66

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


मुझे यह देखने में दिलचस्पी होगी कि यह कैसे काम करता है। इसके अलावा tryj.tk सेवा टूटी हुई प्रतीत होती है ("लोकलस्टोरेज पढ़ने में विफल ..." और "$ (...)। गतिमान एक फ़ंक्शन नहीं है")
डेव

@ क्या वह साइट मेरे लिए भी क्रोम पर काम नहीं करती है, लेकिन अगर मैं IE या एज का उपयोग करने की कोशिश करता हूं, तो काम करता है, हालांकि अगर आप इसमें रुचि रखते हैं तो मैं J ( लिंक ) इंस्टॉल करने की सलाह देता हूं !
मील

@ मीलों अजीब, मेरे लिए यह सभी ब्राउज़रों (एफएफ, क्रोम, आईई) के लिए काम करता है।
रैंडम ऑग

इसने क्रोम का उपयोग करके मेरे लिए काम किया, लेकिन इसने कुछ महीने पहले काम करना बंद कर दिया और डेव के समान त्रुटि संदेश का जवाब देना शुरू किया
मील

@ कुछ समय मिलने पर मैं करूंगा।
यादृच्छिक

1

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

n=>[...Array(n)].map(g=(_,i)=>i?[...g(_,n%i),i]:[],r=0).reduce(g=(x,y,i)=>x.map(e=>r+=!y.includes(e))&&i?g(y,x):x)|r

एक सेट अंतर फ़ंक्शन का अभाव वास्तव में दर्द होता है, लेकिन कुछ रचनात्मक पुनरावृत्ति बाइट काउंट को थोड़ा कम कर देता है। संपादित करें: एक अनावश्यक पैरामीटर को हटाकर 2 बाइट्स सहेजे गए।

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