अतीत की यादों की शौकीन यादें


34

पर विचार करें अभाज्य संख्या पी , आधार से 10 में लिखा स्मृति के पी सख्ती से कम अलग अभाज्य संख्या की संख्या के रूप में परिभाषित किया गया है पी के सबस्ट्रिंग के रूप में निहित हैं पी

चुनौती

इनपुट के रूप में एक गैर-नकारात्मक पूर्णांक n को देखते हुए , सबसे छोटा अभाज्य p ज्ञात करें जैसे p में स्मृति n है । यह है कि, वास्तव में सबसे छोटा प्रधानमंत्री को खोजने n सबस्ट्रिंग के रूप में विशिष्ट सख्ती से कम अभाज्य संख्या।

इनपुट

इनपुट को किसी भी मानक प्रारूप के माध्यम से लिया जा सकता है। आपको सबसे बड़े n तक इनपुट का समर्थन करना चाहिए , ताकि आउटपुट ओवरफ्लो न हो। संदर्भ के लिए, 4294967291 32 बिट्स में सबसे बड़ा प्राइम है।

उत्पादन

आउटपुट STDOUT को लिखा जा सकता है या किसी फ़ंक्शन से लौटाया जा सकता है।

उदाहरण

नंबर 2 में मेमोरी 0 है क्योंकि इसमें सब्सट्रिंग के रूप में कोई सख्ती नहीं है।

113 नंबर मेमोरी के साथ सबसे छोटा प्राइम है। नंबर 3, 13 और 11 एकमात्र प्राइम सब्सट्रिंग्स हैं और 113 से छोटे प्राइम में कोई 3 प्राइमरी सब्सट्रिंग्स नहीं हैं।

अनुक्रम के पहले 10 पद, n = 0 से शुरू होते हैं, हैं

2, 13, 23, 113, 137, 1237, 1733, 1373, 12373, 11317

ध्यान दें

यह OEIS में A079397 है।

लीडरबोर्ड

var QUESTION_ID=55406,OVERRIDE_USER=20469;function answersUrl(e){return"http://api.stackexchange.com/2.2/questions/"+QUESTION_ID+"/answers?page="+e+"&pagesize=100&order=desc&sort=creation&site=codegolf&filter="+ANSWER_FILTER}function commentUrl(e,s){return"http://api.stackexchange.com/2.2/answers/"+s.join(";")+"/comments?page="+e+"&pagesize=100&order=desc&sort=creation&site=codegolf&filter="+COMMENT_FILTER}function getAnswers(){jQuery.ajax({url:answersUrl(answer_page++),method:"get",dataType:"jsonp",crossDomain:!0,success:function(e){answers.push.apply(answers,e.items),answers_hash=[],answer_ids=[],e.items.forEach(function(e){e.comments=[];var s=+e.share_link.match(/\d+/);answer_ids.push(s),answers_hash[s]=e}),e.has_more||(more_answers=!1),comment_page=1,getComments()}})}function getComments(){jQuery.ajax({url:commentUrl(comment_page++,answer_ids),method:"get",dataType:"jsonp",crossDomain:!0,success:function(e){e.items.forEach(function(e){e.owner.user_id===OVERRIDE_USER&&answers_hash[e.post_id].comments.push(e)}),e.has_more?getComments():more_answers?getAnswers():process()}})}function getAuthorName(e){return e.owner.display_name}function process(){var e=[];answers.forEach(function(s){var r=s.body;s.comments.forEach(function(e){OVERRIDE_REG.test(e.body)&&(r="<h1>"+e.body.replace(OVERRIDE_REG,"")+"</h1>")});var a=r.match(SCORE_REG);a&&e.push({user:getAuthorName(s),size:+a[2],language:a[1],link:s.share_link})}),e.sort(function(e,s){var r=e.size,a=s.size;return r-a});var s={},r=1,a=null,n=1;e.forEach(function(e){e.size!=a&&(n=r),a=e.size,++r;var t=jQuery("#answer-template").html();t=t.replace("{{PLACE}}",n+".").replace("{{NAME}}",e.user).replace("{{LANGUAGE}}",e.language).replace("{{SIZE}}",e.size).replace("{{LINK}}",e.link),t=jQuery(t),jQuery("#answers").append(t);var o=e.language;/<a/.test(o)&&(o=jQuery(o).text()),s[o]=s[o]||{lang:e.language,user:e.user,size:e.size,link:e.link}});var t=[];for(var o in s)s.hasOwnProperty(o)&&t.push(s[o]);t.sort(function(e,s){return e.lang>s.lang?1:e.lang<s.lang?-1:0});for(var c=0;c<t.length;++c){var i=jQuery("#language-template").html(),o=t[c];i=i.replace("{{LANGUAGE}}",o.lang).replace("{{NAME}}",o.user).replace("{{SIZE}}",o.size).replace("{{LINK}}",o.link),i=jQuery(i),jQuery("#languages").append(i)}}var ANSWER_FILTER="!t)IWYnsLAZle2tQ3KqrVveCRJfxcRLe",COMMENT_FILTER="!)Q2B_A2kjfAiU78X(md6BoYk",answers=[],answers_hash,answer_ids,answer_page=1,more_answers=!0,comment_page;getAnswers();var SCORE_REG=/<h\d>\s*([^\n,]*[^\s,]),.*?(\d+)(?=[^\n\d<>]*(?:<(?:s>[^\n<>]*<\/s>|[^\n<>]+>)[^\n\d<>]*)*<\/h\d>)/,OVERRIDE_REG=/^Override\s*header:\s*/i;
body{text-align:left!important}#answer-list,#language-list{padding:10px;width:290px;float:left}table thead{font-weight:700}table td{padding:5px}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <link rel="stylesheet" type="text/css" href="//cdn.sstatic.net/codegolf/all.css?v=83c949450c8b"> <div id="answer-list"> <h2>Leaderboard</h2> <table class="answer-list"> <thead> <tr><td></td><td>Author</td><td>Language</td><td>Size</td></tr></thead> <tbody id="answers"> </tbody> </table> </div><div id="language-list"> <h2>Winners by Language</h2> <table class="language-list"> <thead> <tr><td>Language</td><td>User</td><td>Score</td></tr></thead> <tbody id="languages"> </tbody> </table> </div><table style="display: none"> <tbody id="answer-template"> <tr><td>{{PLACE}}</td><td>{{NAME}}</td><td>{{LANGUAGE}}</td><td>{{SIZE}}</td><td><a href="{{LINK}}">Link</a></td></tr></tbody> </table> <table style="display: none"> <tbody id="language-template"> <tr><td>{{LANGUAGE}}</td><td>{{NAME}}</td><td>{{SIZE}}</td><td><a href="{{LINK}}">Link</a></td></tr></tbody> </table>


क्या रनिंग टाइम की कोई सीमा है?
बीटा डिके

@ बटेडेके नोप।
एलेक्स ए।

जवाबों:


8

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

f&}TPTqQlf}YPY{sMP.:`T

प्रदर्शन , टेस्ट हार्नेस

स्पष्टीकरण:

f&}TPTqQlf}YPY{sMP.:`T
                          Implicit: Q = eval(input())
f                         Starting at T=1 and counting up, return the first T where
                    `T    repr(T)
                  .:      all substrings
                 P        except T itself
               sM         converted to integers
              {           unique examples only
         f                filter on
          }YPY            Y is in the prime factorization of Y, e.g. Y is prime.
      qQl                 Q == len of the above, that is, T has memory Q,
 &}TPT                    and T is prime, (is in its prime factorization.)

क्या आप इस्तेमाल नहीं कर सकते थे P_Yऔर P_Tइसके बजाय }YPYऔर }TPTफिर वापस?
एरिक आउटगॉल्फ

7

CJam, 33 31 30 बाइट्स

1{)__mp*{_mp2$s@s#)*},,easi^}g

यह एक पूर्ण प्रोग्राम है जो इनपुट को कमांड-लाइन तर्क के रूप में पढ़ता है।

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

परीक्षण चालन

$ time cjam <(echo '1{)__mp*,{_mp2$s@s#)*},,easi^}g') 9
11317
real    0m3.562s
user    0m4.065s
sys     0m0.177s

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

1       e# Push I := 1 on the stack.
{       e# Do:
  )__   e#   Increment I and push two copies.
  mp*   e#   Check the last copy for primality and multiply with the first copy.
        e#   This pushes R := I if I is prime and R := 0 if it is composite.
  {     e#   Filter; for each J in [0 ... R-1]:
    _mp e#     Push a copy of J and check for primality.
    2$s e#     Push a copy of I and cast to string.
    @s  e#     Rotate the original J on top of the stack and cast to string.
    #   e#     Find the index (-1 if not found) of the latter in the former.
    )*  e#     Increment the index and multiply it with the result from `mp'.
        e#     This yields 0 iff J is composite or not a subtring of I.
  },    e#   Keep J if the product is non-zero.
  ,     e#   Push the length of the filtered range.
  easi  e#   Cast the array of command-line arguments to string, then to integer.
  ^     e#   XOR it with the length of the filtered range.
}g      e# Repeat while theresult is non-zero.

6

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

li2sa{_)\{1$\#)},,3$-}{i{)_mp!}gsa+}w]W=

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

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

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

स्पष्टीकरण:

li    Get input and convert to integer.
2sa   Seed list of primes with ["2"]. The primes are stored as strings to make
      the later substring search more streamlined.
{     Start of while loop condition.
  _   Copy list of primes.
  )     Pop off last prime from list.
  \     Swap remaining list to top.
  {     Start of filter block for substring matches with all smaller primes.
    1$    Copy test prime to top.
    \     Swap the smaller prime to top to get correct order for substring search.
    #     Search.
    )     Increment to get truthy value (Search returns -1 if not found).
  },    End of filter. We have a list of smaller primes that are substrings now.
  ,     Count list entries.
  3$    Copy input n to top.
  -     Subtract the two for comparison. If they are different, continue loop.
}     End of while loop condition.
{     Start of while loop body. We need to generate the next prime.
  i     The largest prime so far is still on the stack, but as string.
        Convert it to integer.
  {     Start of loop for prime candidates.
    )     Increment current candidate value.
    _mp   Check if it is prime.
    !     Negate, loop needs to continue if it is not a prime.
  }g    End loop for prime candidates. On exit, next prime is found.
  sa+   Convert it to string, and add it to list of primes.
}w    End of while loop body.
]W=   Solution is at top of stack. Discard other stack entries.

4

पायथ - 25 बाइट्स

नेस्टेड फ़िल्टर, मेमोरी की गणना करने के लिए आंतरिक, सबसे पहले यह पता लगाने के लिए कि मेमोरी की आवश्यकता है।

f&!tPTqlf&!tPY}`Y`TtStTQ2

टेस्ट सूट


r2Tइसके बजायtStT
जकुब


2

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

n=>{for(a=[],i=2;a.filter(c=>(''+i).search(c)+1).length-n-1;a.push(i))while(!a.every(c=>i%c))i++;return i}

यहाँ स्पष्टीकरण के साथ एक ungolfed संस्करण है:

n=>{
  /**
   * a = list of primes
   * i = current integer
   * Iterate until number of members in a that are substring of i == n-1
   * After each iteration push the current value of i onto a
   */
  for(a=[],i=2; a.filter(c=>(''+i).search(c)+1).length-n-1; a.push(i)) {
    // Iterate until no member of a exactly divides i and increment i per iteration
    while(!a.every(c=>i%c)) i++;
  }
  return i;
}

बेशक यह जल्दी से बल्कि धीमी गति से हो जाता है। हालांकि ओपी ने कहा है कि समय की कोई सीमा नहीं है।


अच्छा समाधान है, की सरल उपयोग aऔर i%cप्रधानमंत्री सत्ता के लिए चेक करें। आप को बदलने के द्वारा दो बाइट्स बचा सकता है {return i}else{a.push(i)}के लिए return i;else a.push(i)मेरा मानना है कि गुमनाम कार्यों के रूप में अच्छी तरह से की अनुमति दी जाती है, जो शुरुआत में दो और बाइट्स की बचत होगी।
ETHproductions

@ETHproductions धन्यवाद उस के बारे में नहीं सोचा था। हालाँकि मैं 7 बाइट्स से दाढ़ी बनाने और सभी if...elseलॉजिक को एक लूप में लपेट कर निकालने में कामयाब रहा हूँ ।
जॉर्ज रीथ

वाह, यह स्मार्ट है! क्या होगा अगर आप के i++साथ संयुक्त i%c?
ETHproductions

@ETHproductions काम नहीं करेगा क्योंकि जो कि हर मूल्य के लिए पुनरावृति करेगा aऔर अगली कॉल में गलत होगा iउदाहरण के लिए, जब हमने 10 बार पाया है कि यह प्रत्येक बाहरी लूप पुनरावृत्ति के लिए 10 बार पुनरावृति करेगा।
जॉर्ज रिथ

@ETHproductions आह हां मैं मूल रूप से पुनरावर्तन का उपयोग करना चाहता था, लेकिन ओपी की न्यूनतम आवश्यकताओं को पूरा करने से पहले यह स्टैक सीमा तक पहुंच गया होगा। अब इसका रिफलेक्ट होना इस तरह संभव होना चाहिए ... इस पर ...
जॉर्ज रीथ

2

Brachylog (2), 12 बाइट्स, भाषा चुनौती देती है

~{ṗ≜{sṗ}ᵘkl}

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

यह पहले 13 बाइट्स का उपयोग कर रहा था ᶠd , लेकिन अब इसे एक संक्षिप्त नाम दिया गया है , इसे 12 तक काट दिया गया है। जैसा कि भाषा वैसे भी चुनौती को स्थगित कर देती है, और विशेषता यह है कि इस चुनौती के लिए विशेष रूप से जोड़ा नहीं गया था, मैं भी हो सकता है इसका इस्तेमाल करें।

जैसा कि ब्रेजलॉग में हमेशा होता है, यह एक फ़ंक्शन है, न कि एक पूर्ण कार्यक्रम।

व्याख्या

~{ṗ≜{sṗ}ᵘkl}
~{         }  Find a value for which the following is true:
  ṗ             The value is prime;
   ≜            (evaluation strategy hint; avoids an infinite loop)
    {  }ᵘ       The set of unique
     sṗ         substrings which are prime
          l     has a length equal to {the input}
         k      when one element is removed.

यह हमें उस संपत्ति के साथ सबसे छोटा प्राइम देता है जिसे हम चाहते हैं, क्योंकि 0 के पास मानों की जाँच करता है।


1

अजगर 2, 163 154 बाइट्स

मैं गोल्फ होने के लिए बहुत थक गया हूँ .. उम्मीद है कि जब मैं कल उठूंगा तो मैं इसमें सुधार कर सकता हूं।

p=lambda n:all(n%x for x in range(2,n))
g=input()
s=2
while not(p(s)and len([l for l in[str(x)for x in range(2,s)if p(x)]if l in str(s)])==g):s+=1
print s

1

जूलिया, 86 बाइट्स

n->for i=1:~0>>>1 isprime(i)&&sum(j->contains("$i","$j"),primes(i-1))==n&&return i;end

यह व्यावहारिक रूप से आत्म-व्याख्यात्मक है। सभी पॉजिटिव पूर्णांक पर लूप करें, और प्रत्येक बार एक प्राइम पाए जाने पर, एक बूलियन एरे को इंगित करता है कि क्या वर्तमान से कम प्राइम का सेट वर्तमान के सबस्ट्रिंग हैं। यदि यह आवश्यक संख्याओं में से किसी एक को ढूँढता है, तो उस मान को लौटाएँ।

रनिंग टाइम n = 11 के लिए सुस्त हो जाता है, और 11 से अधिक मूल्यों की संभावना है - विशेष रूप से, मेरे लैपटॉप पर, n = 11 को 33 सेकंड के लिए लगता है।


स्वच्छ और सुरुचिपूर्ण समाधान, भले ही यह केवल 64-बिट सिस्टम पर काम करता है (इसके लिए जूलिया प्रकार प्रणाली को दोष देता है - 32-बिट प्लेटफॉर्म पर 2^63मूल्यांकन करता है 0, क्योंकि Int3232-बिट सिस्टम - सिक!) पर पूर्णांक शाब्दिक के लिए जूलिया चूकता है। 32-बिट सिस्टम पर समाधान कार्य करने के लिए सबसे छोटा मुहावरा for i=1:uint(-1)तब होगा , लेकिन इसकी लागत 2 बाइट्स अधिक होती है। हालाँकि, सभी प्लेटफ़ॉर्म पर गोल्फ के समाधानों का परीक्षण करना कठिन है, इसलिए +1।
pawel.boczarski

@ pawel.boczarski - बिट-शिफ्टिंग का उपयोग करके मैं इसे ठीक कर सकता हूं। देखिए ...
Glen O

मैंने "मैप" को भी हटा दिया, क्योंकि यह योग के अंदर निरर्थक है, क्योंकि योग एक ऐसा फ़ंक्शन ले सकता है जो योग से पहले प्रत्येक शब्द पर लागू होता है।
ग्लेन ओ

0

हास्केल, १४ ९ १४ 147 144 बाइट्स

(127 बाइट्स importघोषणा की गिनती नहीं )।

import Data.List
i x=x`elem`nubBy(((>1).).gcd)[2..x]
f n=[p|p<-[2..],i p,n==length(nub[x|x<-[read b|a<-tails$show p,b<-tail$inits a],i x])-1]!!0

डेटा को छोड़ दें। सूची> मानचित्र f [0..20]
[2,13,23,113,137,1237,1733,1373,12373,11317,23719, बाधित।

उपरोक्त आउटपुट का निर्माण लंबी परिभाषा के साथ हुआ था

i x=and$[x>1]++[rem x n>0|n<-[2..x-1]]

नया, 3 चार्ट छोटा, परिभाषा बहुत धीमी है, मैं धैर्य खोने और गर्भपात करने से पहले अनुक्रम में केवल 5 पहले नंबर प्राप्त कर सकता था।



0

PHP, 124 बाइट्स

for($p=1;;){for($i=$c=0;$i-1;)for($i=++$p;$p%--$i;);$m[]=$p;foreach($m as$q)$c+=!!strstr($p,"$q");$c-1-$argv[1]?:die("$p");}

कमांड लाइन तर्क से इनपुट लेता है; साथ चलाना -r

टूट - फूट

for($p=1;;)
{
    for($i=$c=0;$i-1;)for($i=++$p;$p%--$i;);    // find prime $p
    $m[]=$p;                                    // remember that prime
    foreach($m as$q)$c+=!!strstr($p,"$q");      // count memory primes
    $c-1-$argv[1]?:die("$p");                   // if memory==N, exit
}

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