​Cuban​ ​PrimesIs this number a prime?List Prime NumbersLeyland NumbersExcessive IntegersClosest Woodall PrimePalindromic Primes without 11Is it a weak prime?Primes other than OptimusPrimus-Orderus PrimesRepeated Digit PrimesBertrand's PrimesSome Lonely Primes

Array Stutter Implementation

Why are C64 games inconsistent with which joystick port they use?

How to prevent bad sectors?

Plot twist where the antagonist wins

Looking for a soft substance that doesn't dissolve underwater

At what point in European history could a government build a printing press given a basic description?

Command to Search for Filenames Exceeding 143 Characters?

Why does the 6502 have the BIT instruction?

How many chess players are over 2500 Elo?

Mother abusing my finances

What is the largest (size) solid object ever dropped from an airplane to impact the ground in freefall?

Why is this Simple Puzzle impossible to solve?

Full horizontal justification in table

What is the difference between “/private/var/vm” and “/vm”?

Different circular sectors as new logo of the International System

How did early x86 BIOS programmers manage to program full blown TUIs given very few bytes of ROM/EPROM?

analysis of BJT PNP type - why they can use voltage divider?

Is CD audio quality good enough for the final delivery of music?

I think I may have violated academic integrity last year - what should I do?

Why do airplanes use an axial flow jet engine instead of a more compact centrifugal jet engine?

Is this resistor leaking? If so, is it a concern?

Approximate solution: factorial and exponentials

Forward and backward integration -- cause of errors

How can I find where certain bash function is defined?



​Cuban​ ​Primes


Is this number a prime?List Prime NumbersLeyland NumbersExcessive IntegersClosest Woodall PrimePalindromic Primes without 11Is it a weak prime?Primes other than OptimusPrimus-Orderus PrimesRepeated Digit PrimesBertrand's PrimesSome Lonely Primes













20












$begingroup$


Given a natural number $n$, return the $n$-th cuban prime.



Cuban Primes



A cuban prime is a prime number of the form



$$p = fracx^3-y^3x-y$$



where $y>0$ and $x = 1+y$ or $x = 2+y$



Details



  • You may use 0 or 1 based indexing, whatever suits you best.

  • You can return the $n$-th prime given the index $n$ or the first $n$ primes in increasing order, or alternatively you can return an infinite list/generator that produces the primes in increasing order.

Test cases



The first few terms are following:



(#1-13) 7, 13, 19, 37, 61, 109, 127, 193, 271, 331, 397, 433, 547,
(#14-24) 631, 769, 919, 1201, 1453, 1657, 1801, 1951, 2029, 2269, 2437,
(#25-34) 2791, 3169, 3469, 3571, 3889, 4219, 4447, 4801, 5167, 5419,
(#35-43) 6211, 7057, 7351, 8269, 9241, 10093, 10267, 11719, 12097,
(#44-52) 12289, 13267, 13669, 13873, 16651, 18253, 19441, 19927, 20173


More terms can be found on OEIS: They are split up in two sequences, depending on wheter $x = 1+y $ or $x = 2+y$: A002407 and A002648












share|improve this question











$endgroup$







  • 2




    $begingroup$
    Can we return the first n primes not sorted?
    $endgroup$
    – J42161217
    May 14 at 13:29










  • $begingroup$
    @J42161217 No, the primes should be in increasing order.
    $endgroup$
    – flawr
    May 14 at 14:30















20












$begingroup$


Given a natural number $n$, return the $n$-th cuban prime.



Cuban Primes



A cuban prime is a prime number of the form



$$p = fracx^3-y^3x-y$$



where $y>0$ and $x = 1+y$ or $x = 2+y$



Details



  • You may use 0 or 1 based indexing, whatever suits you best.

  • You can return the $n$-th prime given the index $n$ or the first $n$ primes in increasing order, or alternatively you can return an infinite list/generator that produces the primes in increasing order.

Test cases



The first few terms are following:



(#1-13) 7, 13, 19, 37, 61, 109, 127, 193, 271, 331, 397, 433, 547,
(#14-24) 631, 769, 919, 1201, 1453, 1657, 1801, 1951, 2029, 2269, 2437,
(#25-34) 2791, 3169, 3469, 3571, 3889, 4219, 4447, 4801, 5167, 5419,
(#35-43) 6211, 7057, 7351, 8269, 9241, 10093, 10267, 11719, 12097,
(#44-52) 12289, 13267, 13669, 13873, 16651, 18253, 19441, 19927, 20173


More terms can be found on OEIS: They are split up in two sequences, depending on wheter $x = 1+y $ or $x = 2+y$: A002407 and A002648












share|improve this question











$endgroup$







  • 2




    $begingroup$
    Can we return the first n primes not sorted?
    $endgroup$
    – J42161217
    May 14 at 13:29










  • $begingroup$
    @J42161217 No, the primes should be in increasing order.
    $endgroup$
    – flawr
    May 14 at 14:30













20












20








20


3



$begingroup$


Given a natural number $n$, return the $n$-th cuban prime.



Cuban Primes



A cuban prime is a prime number of the form



$$p = fracx^3-y^3x-y$$



where $y>0$ and $x = 1+y$ or $x = 2+y$



Details



  • You may use 0 or 1 based indexing, whatever suits you best.

  • You can return the $n$-th prime given the index $n$ or the first $n$ primes in increasing order, or alternatively you can return an infinite list/generator that produces the primes in increasing order.

Test cases



The first few terms are following:



(#1-13) 7, 13, 19, 37, 61, 109, 127, 193, 271, 331, 397, 433, 547,
(#14-24) 631, 769, 919, 1201, 1453, 1657, 1801, 1951, 2029, 2269, 2437,
(#25-34) 2791, 3169, 3469, 3571, 3889, 4219, 4447, 4801, 5167, 5419,
(#35-43) 6211, 7057, 7351, 8269, 9241, 10093, 10267, 11719, 12097,
(#44-52) 12289, 13267, 13669, 13873, 16651, 18253, 19441, 19927, 20173


More terms can be found on OEIS: They are split up in two sequences, depending on wheter $x = 1+y $ or $x = 2+y$: A002407 and A002648












share|improve this question











$endgroup$




Given a natural number $n$, return the $n$-th cuban prime.



Cuban Primes



A cuban prime is a prime number of the form



$$p = fracx^3-y^3x-y$$



where $y>0$ and $x = 1+y$ or $x = 2+y$



Details



  • You may use 0 or 1 based indexing, whatever suits you best.

  • You can return the $n$-th prime given the index $n$ or the first $n$ primes in increasing order, or alternatively you can return an infinite list/generator that produces the primes in increasing order.

Test cases



The first few terms are following:



(#1-13) 7, 13, 19, 37, 61, 109, 127, 193, 271, 331, 397, 433, 547,
(#14-24) 631, 769, 919, 1201, 1453, 1657, 1801, 1951, 2029, 2269, 2437,
(#25-34) 2791, 3169, 3469, 3571, 3889, 4219, 4447, 4801, 5167, 5419,
(#35-43) 6211, 7057, 7351, 8269, 9241, 10093, 10267, 11719, 12097,
(#44-52) 12289, 13267, 13669, 13873, 16651, 18253, 19441, 19927, 20173


More terms can be found on OEIS: They are split up in two sequences, depending on wheter $x = 1+y $ or $x = 2+y$: A002407 and A002648









code-golf math number sequence primes






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited May 14 at 18:28







flawr

















asked May 14 at 13:10









flawrflawr

27.8k670198




27.8k670198







  • 2




    $begingroup$
    Can we return the first n primes not sorted?
    $endgroup$
    – J42161217
    May 14 at 13:29










  • $begingroup$
    @J42161217 No, the primes should be in increasing order.
    $endgroup$
    – flawr
    May 14 at 14:30












  • 2




    $begingroup$
    Can we return the first n primes not sorted?
    $endgroup$
    – J42161217
    May 14 at 13:29










  • $begingroup$
    @J42161217 No, the primes should be in increasing order.
    $endgroup$
    – flawr
    May 14 at 14:30







2




2




$begingroup$
Can we return the first n primes not sorted?
$endgroup$
– J42161217
May 14 at 13:29




$begingroup$
Can we return the first n primes not sorted?
$endgroup$
– J42161217
May 14 at 13:29












$begingroup$
@J42161217 No, the primes should be in increasing order.
$endgroup$
– flawr
May 14 at 14:30




$begingroup$
@J42161217 No, the primes should be in increasing order.
$endgroup$
– flawr
May 14 at 14:30










16 Answers
16






active

oldest

votes


















23












$begingroup$


JavaScript (V8), 54 bytes



A full program that prints cuban primes forever.





for(x=0;;)for(k=N=~(3/4*++x*x);N%++k;);~k


Try it online!



NB: Unless you have infinite paper in your printer, do not attempt to run this in your browser console, where print() may have a different meaning.




JavaScript (ES6),  63 61 60  59 bytes



Returns the $n$-th cuban prime, 1-indexed.





f=(n,x)=>(p=k=>N%++k?p(k):n-=!~k)(N=~(3/4*x*x))?f(n,-~x):-N


Try it online!



How?



This is based on the fact that cuban primes are primes of the form:



$$p_n=leftlfloorfrac3n^24rightrfloor+1,;nge3$$



The above formula can be written as:



$$p_n=begincases
dfrac3n^2+14;text if ntext is odd\
dfrac3n^2+44;text if ntext is even
endcases
$$



or for any $y>0$:



$$p_2y+1=dfrac3(2y+1)^2+14=3y^2+3y+1$$
$$p_2y+2=dfrac3(2y+2)^2+44=3y^2+6y+4$$



which is $dfracx^3-y^3x-y$ for $x=y+1$ and $x=y+2$ respectively.






share|improve this answer











$endgroup$




















    7












    $begingroup$


    05AB1E, 16 12 9 bytes



    Generates an infinite list.

    Saved 4 bytes with Kevin Cruijssen's port of Arnaulds formula.

    Saved another 3 bytes thanks to Grimy



    ∞n3*4÷>ʒp


    Try it online!



    Explanation



    ∞ # on the list of infinite positive integers
    n3*4÷> # calculate (3*N^2)//4+1 for each
    ʒp # and filter to only keep primes





    share|improve this answer











    $endgroup$












    • $begingroup$
      You've made a typo in your explanation: "put a copy of N^2+3 on the stack" should be 3*N^2. Also, why the ) instead of ¯? Because it's easier to type? And for some reason I have the feeling the NnN‚3*¬sO‚ can be 1 byte shorter, but I'm not seeing it. A slight equal-byte alternative is Nn3*DN3*+‚. But I'm probably just seeing things that aren't there.. ;) Nice answer, so +1 from me.
      $endgroup$
      – Kevin Cruijssen
      May 14 at 14:30






    • 1




      $begingroup$
      I actually tried to port my answer to 05AB1E, but failed miserably. :D
      $endgroup$
      – Arnauld
      May 14 at 15:09






    • 1




      $begingroup$
      Actually, generating an infinite list is more convenient: 9 bytes with ∞n3*4÷>ʒp
      $endgroup$
      – Grimy
      May 14 at 15:45






    • 1




      $begingroup$
      OK, I'm not used to specs that contradict themselves. :-)
      $endgroup$
      – WGroleau
      May 14 at 21:11






    • 6




      $begingroup$
      @WGroleau I assume you've never developed software professionally then. I'm more concerned when I get specs that don't contradict themselves.
      $endgroup$
      – MikeTheLiar
      May 14 at 21:29


















    7












    $begingroup$


    R, 75 73 bytes





    n=scan()
    while(F<n)F=F+any(!(((T<-T+1)*1:4-1)/3)^.5%%1)*all(T%%(3:T-1))
    T


    Try it online!



    -2 bytes by noticing that I can remove brackets if I use * instead of & (different precedence).



    Outputs the nth Cuban prime (1-indexed).



    It uses the fact (given in OEIS) that Cuban primes are of the form $p=1+3n^2$ or $4p=1+3n^2$ for some $n$, i.e. $n=sqrtfracacdot p-13$ is an integer for $a=1$ or $a=4$.



    The trick is that no prime can be of the form $2p=1+3n^2$ or $3p=1+3n^2$ (*), so we can save 2 bytes by checking the formula for $ain1, 2, 3, 4$ (1:4) instead of $ain1, 4$ (c(1,4)).



    Slightly ungolfed version of the code:



    # F and T are implicitly initialized at 0 and 1
    # F is number of Cuban primes found so far
    # T is number currently being tested for being a Cuban prime
    n = scan() # input
    while(F<n)
    T = T+1 # increment T
    F = F + # increment F if
    (!all(((T*1:4-1)/3)^.5 %% 1) # there is an integer of the form sqrt(((T*a)-1)/3)
    & all(T%%(3:T-1))) # and T is prime (not divisible by any number between 2 and T-1)

    T # output T


    (*) No prime can be of the form $3p=1+3n^2$, else $1=3(p-n^2)$ would be divisible by $3$.



    No prime other than $p=2$ (which isn't a Cuban prime) can of the form $2p=1+3n^2$: $n$ would need to be odd, i.e. $n=2k+1$. Expanding gives $2p=4+12k(k+1)$, hence $p=2+6k(k+1)$ and $p$ would be even.






    share|improve this answer











    $endgroup$












    • $begingroup$
      what about avoiding a loop by using an upper bound on the nth Cuban prime?
      $endgroup$
      – Xi'an
      May 15 at 7:31










    • $begingroup$
      @Xi'an I thought about that, but couldn't come up with such a bound. Do you have one?
      $endgroup$
      – Robin Ryder
      May 15 at 13:32


















    5












    $begingroup$


    Wolfram Language (Mathematica), 66 65 56 bytes



    (f=1+⌊3#/4#⌋&;For[n=i=0,i<#,PrimeQ@f@++n&&i++];f@n)&


    Try it online!



    • J42161217 -1 by using ⌊ ⌋ instead of Floor[ ]



    • attinat




      • -1 by using ⌊3#/4#⌋ instead of ⌊3#^2/4⌋


      • -8 for For[n=i=0,i<#,PrimeQ@f@++n&&i++] instead of n=2;i=#;While[i>0,i-=Boole@PrimeQ@f@++n]






    share|improve this answer











    $endgroup$








    • 1




      $begingroup$
      65 bytes. Welcome to ppcg. Nice first answer! +1
      $endgroup$
      – J42161217
      May 14 at 18:39










    • $begingroup$
      Thanks! (Long time lurker.) I couldn't quite parse your existing answer so I wrote my own and it came out a little shorter. I might do a Python one too.
      $endgroup$
      – speedstyle
      May 14 at 18:57






    • 2




      $begingroup$
      56 bytes
      $endgroup$
      – attinat
      May 14 at 21:54










    • $begingroup$
      @attinat I thought Arnauld's formula only worked for n>2 so I didn't start with 0 - although as in your example it works for all n (because it starts 1 1 4 7 13 ... so the primes are 7 13 ...)
      $endgroup$
      – speedstyle
      May 14 at 22:33


















    3












    $begingroup$

    Java 8, 94 88 86 84 bytes





    v->for(int i=3,n,x;;System.out.print(x<1?++n+" ":""))for(x=n=i*i++*3/4;~n%x--<0;);


    -6 bytes by using the Java prime-checker of @SaraJ, so make sure to upvote her!

    -2 bytes thanks to @OlivierGrégoire. Since the first number we check is 7, we can drop the trailing %n from Sara's prime-checker, which is to terminate the loop for n=1.

    -2 bytes thanks to @OlivierGrégoire by porting @Arnauld's answer.



    Outputs space-delimited indefinitely.



    Try it online.



    Explanation (of the old 86 bytes version): TODO: Update explanation



    Uses the formula of @Arnauld's JavaScript answer: $p_n=leftlfloorfrac3n^24rightrfloor+1,;nge3$.



    v-> // Method with empty unused parameter and no return-type
    for(int i=3, // Loop-integer, starting at 3
    n,x // Temp integers
    ; // Loop indefinitely:
    ; // After every iteration:
    System.out.print( // Print:
    n==x? // If `n` equals `x`, which means `n` is a prime:
    n+" " // Print `n` with a space delimiter
    : // Else:
    "")) // Print nothing
    for(n=i*i++*3/4+1, // Set `n` to `(3*i^2)//4+1
    // (and increase `i` by 1 afterwards with `i++`)
    x=1; // Set `x` to 1
    n%++x // Loop as long as `n` modulo `x+1`
    // (after we've first increased `x` by 1 with `++x`)
    >0;); // is not 0 yet
    // (if `n` is equal to `x`, it means it's a prime)





    share|improve this answer











    $endgroup$












    • $begingroup$
      I don't really think it's feasible, but another way of finding the cuban primes uses this formula: v->for(int n=7,i=3,p,x,d,r=0;;i+=++r%2*3,n+=i,System.out.print(x>1?x+" ":""))for(x=n,d=1;++d<n;x=x%d<1?0:n);, maybe someone can use this to golf? I couldn't.
      $endgroup$
      – Olivier Grégoire
      May 16 at 9:03






    • 1




      $begingroup$
      @OlivierGrégoire You can golf yours a bit more by removing the unused ,p and changing i+=++r%2*3,n+=i to n+=i+=++r%2*3, but then I'll still end up at 106 bytes. Using Java 11's String#repeat with prime-regex is 105 bytes: v->(..+?)\1+"))System.out.println(n);.
      $endgroup$
      – Kevin Cruijssen
      May 16 at 9:40











    • $begingroup$
      Yeah, I guessed it wasn't much golfable despite my (now obvious) mistakes. Thanks for giving it a ride ;)
      $endgroup$
      – Olivier Grégoire
      May 16 at 14:02










    • $begingroup$
      @OlivierGrégoire Maybe also good to know for you, but there is apparently a shorter prime-check loop in Java. See my edit and SaraJ's prime-check answer.
      $endgroup$
      – Kevin Cruijssen
      May 16 at 14:30











    • $begingroup$
      I might be wrong, but the last %n isn't required, is it?
      $endgroup$
      – Olivier Grégoire
      May 16 at 14:44


















    2












    $begingroup$


    Wolfram Language (Mathematica), 83 bytes



    (t=1;While[Length[l=Select[Join@@Array[(v=3#^2+1)+3#,v&,t++],PrimeQ]]<#];Sort@l)&


    Try it online!






    share|improve this answer











    $endgroup$




















      2












      $begingroup$


      Jelly, 12 bytes



      ²×3:4‘
      ÇẒ$#Ç


      Try it online!



      Based on @Arnauld’s method. Takes n on stdin and returns that many Cuban primes.






      share|improve this answer









      $endgroup$




















        1












        $begingroup$


        Wolfram Language (Mathematica), 83 bytes



        This solution will output the n-th Cuban prime with the added benefits of being fast and remembering all previous results in the symbol f.



        (d:=1+3y(c=1+y)+3b c;e:=If[PrimeQ@d,n++;f@n=d];For[n=y=b=0,n<#,e;b=1-b;e,y++];f@#)&


        Try it online!






        share|improve this answer









        $endgroup$




















          1












          $begingroup$


          Whitespace, 180 bytes



          [S S S T S N
          _Push_2][S N
          S _Duplicate][N
          S S N
          _Create_Label_OUTER_LOOP][S N
          N
          _Discard_top_stack][S S S T N
          _Push_1][T S S S _Add][S N
          S _Duplicate][S N
          S _Duplicate][T S S N
          _Multiply][S S S T T N
          _Push_3][T S S N
          _Multiply][S S S T S S N
          _Push_4][T S T S _Integer_divide][S S S T N
          _Push_1][T S S S _Add][S S S T N
          _Push_1][S N
          S _Duplicate_1][N
          S S S N
          _Create_Label_INNER_LOOP][S N
          N
          _Discard_top_stack][S S S T N
          _Push_1][T S S S _Add][S N
          S _Duplicate][S N
          S _Duplicate][S T S S T T N
          _Copy_0-based_3rd][T S S T _Subtract][N
          T S T N
          _Jump_to_Label_PRINT_if_0][S T S S T S N
          _Copy_0-based_2nd][S N
          T _Swap_top_two][T S T T _Modulo][S N
          S _Duplicate][N
          T S S S N
          _Jump_to_Label_FALSE_if_0][N
          S N
          S N
          _Jump_to_Label_INNER_LOOP][N
          S S T N
          _Create_Label_PRINT][T N
          S T _Print_as_integer][S S S T S T S N
          _Push_10_(newline)][T N
          S S _Print_as_character][S N
          S _Duplicate][N
          S S S S N
          _Create_Label_FALSE][S N
          N
          _Discard_top_stack][S N
          N
          _Discard_top_stack][N
          S N
          N
          _Jump_to_Label_OUTER_LOOP]


          Letters S (space), T (tab), and N (new-line) added as highlighting only.
          [..._some_action] added as explanation only.



          Outputs newline-delimited indefinitely.



          Try it online (with raw spaces, tabs, and new-lines only).



          Explanation in pseudo-code:



          Port of my Java 8 answer, which also uses the formula from @Arnauld's JavaScript answer: $p_n=leftlfloorfrac3n^24rightrfloor+1,;nge3$.



          Integer i = 2
          Start OUTER_LOOP:
          i = i + 1
          Integer n = i*i*3//4+1
          Integer x = 1
          Start INNER_LOOP:
          x = x + 1
          If(x == n):
          Call function PRINT
          If(n % x == 0):
          Go to next iteration of OUTER_LOOP
          Go to next iteration of INNER_LOOP

          function PRINT:
          Print integer n
          Print character 'n'
          Go to next iteration of OUTER_LOOP





          share|improve this answer









          $endgroup$




















            1












            $begingroup$


            Python 3, 110 108 102 bytes



            Similar method to my Mathematica answer (i.e. isPrime(1+⌊¾n²⌋) else n++)
            using this golfed prime checker and returning an anonymous infinite generator





            from itertools import*
            (x for x in map(lambda n:1+3*n**2//4,count(2)) if all(x%j for j in range(2,x)))


            Try it online!




            • mypetlion -2 because arguably anonymous generators are more allowed than named ones


            • -6 by starting count at 2 +1 so that the and x>1 in the prime checker I borrowed is unnecessary -7





            share|improve this answer











            $endgroup$












            • $begingroup$
              The answer going into a variable is usually not considered a valid form of "output". Could you rework your answer so that the result is either output to stdout or returned by a function?
              $endgroup$
              – mypetlion
              May 14 at 23:01






            • 1




              $begingroup$
              since anonymous functions are allowed, and the challenge explicitly allows an infinite generator, I've removed g=. I had only included it in the first place because it allowed a quick visual on TIO with print(next(g) for i in range(52)).
              $endgroup$
              – speedstyle
              May 15 at 1:15


















            1












            $begingroup$


            Japt, 14 13 bytes



            Adapted from Arnauld's formula. 1-indexed.



            @µXj}f@Ò(X²*¾


            Try it



            1 byte saved thanks to EmbodimentOfIgnorance.






            share|improve this answer











            $endgroup$












            • $begingroup$
              13 bytes? Not tested thoroughly though.
              $endgroup$
              – Embodiment of Ignorance
              May 15 at 2:15










            • $begingroup$
              Thanks, @EmbodimentofIgnorance. I'd tried that but it didn't work; turns out I'd forgotten the (.
              $endgroup$
              – Shaggy
              May 15 at 9:47


















            1












            $begingroup$


            Racket, 124 bytes



            (require math)(define(f n[i 3])(let([t(+(exact-floor(* 3/4 i i))1)][k(+ 1 i)])(if(prime? t)(if(= 0 n)t(f(- n 1)k))(f n k))))


            Try it online!



            Returns the n-th cuban prime, 0-indexed.



            Uses the formula of @Arnauld's JavaScript answer






            share|improve this answer











            $endgroup$




















              1












              $begingroup$


              Python 3, 83 bytes



              prints the cuban primes forever.





              P=k=1
              while 1:P*=k*k;x=k;k+=1;P%k>0==((x/3)**.5%1)*((x/3+.25)**.5%1-.5)and print(k)


              Try it online!



              Based on this prime generator. For every prime it checks whether an integer y exists that fulfills the equation for either $x = 1+y$ or $x=2+y$.



              $$ p=frac(1+y)^3-y^3(1+y)-y = 1 + 3y +3y^2 Leftrightarrow y = -frac12pmsqrtfrac14+fracp-13$$



              $$ p=frac(2+y)^3-y^3(1+y)-y = 4 + 6y +3y^2 Leftrightarrow y = -1 pmsqrtfracp-13$$
              As we only care whether $y$ has an integer solution, we can ignore the $pm$ and $-1$.






              share|improve this answer











              $endgroup$




















                1












                $begingroup$


                Perl 6, 33 31 bytes



                -2 bytes thanks to Grimy





                ¾*$++²xx*


                Try it online!



                Anonymous code block that returns a lazy infinite list of Cuban primes. This uses Arnauld's formula to generate possible cuban primes, then &is-prime to filter them.



                Explanation:



                 # Anonymous code block
                grep &is-prime, # Filter the primes from
                xx* # The infinite list
                ¾* # Of three quarters
                $++² # Of an increasing number squared
                1+| # Add one by ORing with 1





                share|improve this answer











                $endgroup$








                • 1




                  $begingroup$
                  1+0+| can be just 1+|
                  $endgroup$
                  – Grimy
                  May 16 at 10:49


















                0












                $begingroup$


                Pari/GP, 51 bytes



                Using Arnauld's formula.



                n->a=0;for(i=1,n,until(isprime(p=3*a^24+1),a++));p


                Try it online!






                share|improve this answer









                $endgroup$




















                  0












                  $begingroup$

                  APL(NARS), 98 chars, 196 bytes



                  r←h w;y;c;v
                  r←c←y←0⋄→4
                  →3×⍳∼0πv←1+3×y×1+y+←1⋄r←v⋄→0×⍳w≤c+←1
                  →2×⍳∼0πv+←3×y+1⋄c+←1⋄r←v
                  →2×⍳w>c


                  indented :



                  r←h w;y;c;v
                  r←c←y←0⋄→4
                  →3×⍳∼0πv←1+3×y×1+y+←1⋄r←v⋄→0×⍳w≤c+←1
                  →2×⍳∼0πv+←3×y+1⋄c+←1⋄r←v
                  →2×⍳w>c


                  test:



                   h ¨1..20
                  7 13 19 37 61 109 127 193 271 331 397 433 547 631 769 919 1201 1453 1657 1801
                  h 1000
                  25789873
                  h 10000
                  4765143511


                  it is based on: if y in N, one possible Cuban Prime is



                  S1=1+3y(y+1)


                  the the next possible Cuban Prime will be



                  S2=3(y+1)+S1





                  share|improve this answer











                  $endgroup$













                    Your Answer






                    StackExchange.ifUsing("editor", function ()
                    StackExchange.using("externalEditor", function ()
                    StackExchange.using("snippets", function ()
                    StackExchange.snippets.init();
                    );
                    );
                    , "code-snippets");

                    StackExchange.ready(function()
                    var channelOptions =
                    tags: "".split(" "),
                    id: "200"
                    ;
                    initTagRenderer("".split(" "), "".split(" "), channelOptions);

                    StackExchange.using("externalEditor", function()
                    // Have to fire editor after snippets, if snippets enabled
                    if (StackExchange.settings.snippets.snippetsEnabled)
                    StackExchange.using("snippets", function()
                    createEditor();
                    );

                    else
                    createEditor();

                    );

                    function createEditor()
                    StackExchange.prepareEditor(
                    heartbeatType: 'answer',
                    autoActivateHeartbeat: false,
                    convertImagesToLinks: false,
                    noModals: true,
                    showLowRepImageUploadWarning: true,
                    reputationToPostImages: null,
                    bindNavPrevention: true,
                    postfix: "",
                    imageUploader:
                    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
                    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
                    allowUrls: true
                    ,
                    onDemand: true,
                    discardSelector: ".discard-answer"
                    ,immediatelyShowMarkdownHelp:true
                    );



                    );













                    draft saved

                    draft discarded


















                    StackExchange.ready(
                    function ()
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodegolf.stackexchange.com%2fquestions%2f185567%2fcuban-primes%23new-answer', 'question_page');

                    );

                    Post as a guest















                    Required, but never shown

























                    16 Answers
                    16






                    active

                    oldest

                    votes








                    16 Answers
                    16






                    active

                    oldest

                    votes









                    active

                    oldest

                    votes






                    active

                    oldest

                    votes









                    23












                    $begingroup$


                    JavaScript (V8), 54 bytes



                    A full program that prints cuban primes forever.





                    for(x=0;;)for(k=N=~(3/4*++x*x);N%++k;);~k


                    Try it online!



                    NB: Unless you have infinite paper in your printer, do not attempt to run this in your browser console, where print() may have a different meaning.




                    JavaScript (ES6),  63 61 60  59 bytes



                    Returns the $n$-th cuban prime, 1-indexed.





                    f=(n,x)=>(p=k=>N%++k?p(k):n-=!~k)(N=~(3/4*x*x))?f(n,-~x):-N


                    Try it online!



                    How?



                    This is based on the fact that cuban primes are primes of the form:



                    $$p_n=leftlfloorfrac3n^24rightrfloor+1,;nge3$$



                    The above formula can be written as:



                    $$p_n=begincases
                    dfrac3n^2+14;text if ntext is odd\
                    dfrac3n^2+44;text if ntext is even
                    endcases
                    $$



                    or for any $y>0$:



                    $$p_2y+1=dfrac3(2y+1)^2+14=3y^2+3y+1$$
                    $$p_2y+2=dfrac3(2y+2)^2+44=3y^2+6y+4$$



                    which is $dfracx^3-y^3x-y$ for $x=y+1$ and $x=y+2$ respectively.






                    share|improve this answer











                    $endgroup$

















                      23












                      $begingroup$


                      JavaScript (V8), 54 bytes



                      A full program that prints cuban primes forever.





                      for(x=0;;)for(k=N=~(3/4*++x*x);N%++k;);~k


                      Try it online!



                      NB: Unless you have infinite paper in your printer, do not attempt to run this in your browser console, where print() may have a different meaning.




                      JavaScript (ES6),  63 61 60  59 bytes



                      Returns the $n$-th cuban prime, 1-indexed.





                      f=(n,x)=>(p=k=>N%++k?p(k):n-=!~k)(N=~(3/4*x*x))?f(n,-~x):-N


                      Try it online!



                      How?



                      This is based on the fact that cuban primes are primes of the form:



                      $$p_n=leftlfloorfrac3n^24rightrfloor+1,;nge3$$



                      The above formula can be written as:



                      $$p_n=begincases
                      dfrac3n^2+14;text if ntext is odd\
                      dfrac3n^2+44;text if ntext is even
                      endcases
                      $$



                      or for any $y>0$:



                      $$p_2y+1=dfrac3(2y+1)^2+14=3y^2+3y+1$$
                      $$p_2y+2=dfrac3(2y+2)^2+44=3y^2+6y+4$$



                      which is $dfracx^3-y^3x-y$ for $x=y+1$ and $x=y+2$ respectively.






                      share|improve this answer











                      $endgroup$















                        23












                        23








                        23





                        $begingroup$


                        JavaScript (V8), 54 bytes



                        A full program that prints cuban primes forever.





                        for(x=0;;)for(k=N=~(3/4*++x*x);N%++k;);~k


                        Try it online!



                        NB: Unless you have infinite paper in your printer, do not attempt to run this in your browser console, where print() may have a different meaning.




                        JavaScript (ES6),  63 61 60  59 bytes



                        Returns the $n$-th cuban prime, 1-indexed.





                        f=(n,x)=>(p=k=>N%++k?p(k):n-=!~k)(N=~(3/4*x*x))?f(n,-~x):-N


                        Try it online!



                        How?



                        This is based on the fact that cuban primes are primes of the form:



                        $$p_n=leftlfloorfrac3n^24rightrfloor+1,;nge3$$



                        The above formula can be written as:



                        $$p_n=begincases
                        dfrac3n^2+14;text if ntext is odd\
                        dfrac3n^2+44;text if ntext is even
                        endcases
                        $$



                        or for any $y>0$:



                        $$p_2y+1=dfrac3(2y+1)^2+14=3y^2+3y+1$$
                        $$p_2y+2=dfrac3(2y+2)^2+44=3y^2+6y+4$$



                        which is $dfracx^3-y^3x-y$ for $x=y+1$ and $x=y+2$ respectively.






                        share|improve this answer











                        $endgroup$




                        JavaScript (V8), 54 bytes



                        A full program that prints cuban primes forever.





                        for(x=0;;)for(k=N=~(3/4*++x*x);N%++k;);~k


                        Try it online!



                        NB: Unless you have infinite paper in your printer, do not attempt to run this in your browser console, where print() may have a different meaning.




                        JavaScript (ES6),  63 61 60  59 bytes



                        Returns the $n$-th cuban prime, 1-indexed.





                        f=(n,x)=>(p=k=>N%++k?p(k):n-=!~k)(N=~(3/4*x*x))?f(n,-~x):-N


                        Try it online!



                        How?



                        This is based on the fact that cuban primes are primes of the form:



                        $$p_n=leftlfloorfrac3n^24rightrfloor+1,;nge3$$



                        The above formula can be written as:



                        $$p_n=begincases
                        dfrac3n^2+14;text if ntext is odd\
                        dfrac3n^2+44;text if ntext is even
                        endcases
                        $$



                        or for any $y>0$:



                        $$p_2y+1=dfrac3(2y+1)^2+14=3y^2+3y+1$$
                        $$p_2y+2=dfrac3(2y+2)^2+44=3y^2+6y+4$$



                        which is $dfracx^3-y^3x-y$ for $x=y+1$ and $x=y+2$ respectively.







                        share|improve this answer














                        share|improve this answer



                        share|improve this answer








                        edited May 15 at 11:41

























                        answered May 14 at 13:30









                        ArnauldArnauld

                        85.1k7100349




                        85.1k7100349





















                            7












                            $begingroup$


                            05AB1E, 16 12 9 bytes



                            Generates an infinite list.

                            Saved 4 bytes with Kevin Cruijssen's port of Arnaulds formula.

                            Saved another 3 bytes thanks to Grimy



                            ∞n3*4÷>ʒp


                            Try it online!



                            Explanation



                            ∞ # on the list of infinite positive integers
                            n3*4÷> # calculate (3*N^2)//4+1 for each
                            ʒp # and filter to only keep primes





                            share|improve this answer











                            $endgroup$












                            • $begingroup$
                              You've made a typo in your explanation: "put a copy of N^2+3 on the stack" should be 3*N^2. Also, why the ) instead of ¯? Because it's easier to type? And for some reason I have the feeling the NnN‚3*¬sO‚ can be 1 byte shorter, but I'm not seeing it. A slight equal-byte alternative is Nn3*DN3*+‚. But I'm probably just seeing things that aren't there.. ;) Nice answer, so +1 from me.
                              $endgroup$
                              – Kevin Cruijssen
                              May 14 at 14:30






                            • 1




                              $begingroup$
                              I actually tried to port my answer to 05AB1E, but failed miserably. :D
                              $endgroup$
                              – Arnauld
                              May 14 at 15:09






                            • 1




                              $begingroup$
                              Actually, generating an infinite list is more convenient: 9 bytes with ∞n3*4÷>ʒp
                              $endgroup$
                              – Grimy
                              May 14 at 15:45






                            • 1




                              $begingroup$
                              OK, I'm not used to specs that contradict themselves. :-)
                              $endgroup$
                              – WGroleau
                              May 14 at 21:11






                            • 6




                              $begingroup$
                              @WGroleau I assume you've never developed software professionally then. I'm more concerned when I get specs that don't contradict themselves.
                              $endgroup$
                              – MikeTheLiar
                              May 14 at 21:29















                            7












                            $begingroup$


                            05AB1E, 16 12 9 bytes



                            Generates an infinite list.

                            Saved 4 bytes with Kevin Cruijssen's port of Arnaulds formula.

                            Saved another 3 bytes thanks to Grimy



                            ∞n3*4÷>ʒp


                            Try it online!



                            Explanation



                            ∞ # on the list of infinite positive integers
                            n3*4÷> # calculate (3*N^2)//4+1 for each
                            ʒp # and filter to only keep primes





                            share|improve this answer











                            $endgroup$












                            • $begingroup$
                              You've made a typo in your explanation: "put a copy of N^2+3 on the stack" should be 3*N^2. Also, why the ) instead of ¯? Because it's easier to type? And for some reason I have the feeling the NnN‚3*¬sO‚ can be 1 byte shorter, but I'm not seeing it. A slight equal-byte alternative is Nn3*DN3*+‚. But I'm probably just seeing things that aren't there.. ;) Nice answer, so +1 from me.
                              $endgroup$
                              – Kevin Cruijssen
                              May 14 at 14:30






                            • 1




                              $begingroup$
                              I actually tried to port my answer to 05AB1E, but failed miserably. :D
                              $endgroup$
                              – Arnauld
                              May 14 at 15:09






                            • 1




                              $begingroup$
                              Actually, generating an infinite list is more convenient: 9 bytes with ∞n3*4÷>ʒp
                              $endgroup$
                              – Grimy
                              May 14 at 15:45






                            • 1




                              $begingroup$
                              OK, I'm not used to specs that contradict themselves. :-)
                              $endgroup$
                              – WGroleau
                              May 14 at 21:11






                            • 6




                              $begingroup$
                              @WGroleau I assume you've never developed software professionally then. I'm more concerned when I get specs that don't contradict themselves.
                              $endgroup$
                              – MikeTheLiar
                              May 14 at 21:29













                            7












                            7








                            7





                            $begingroup$


                            05AB1E, 16 12 9 bytes



                            Generates an infinite list.

                            Saved 4 bytes with Kevin Cruijssen's port of Arnaulds formula.

                            Saved another 3 bytes thanks to Grimy



                            ∞n3*4÷>ʒp


                            Try it online!



                            Explanation



                            ∞ # on the list of infinite positive integers
                            n3*4÷> # calculate (3*N^2)//4+1 for each
                            ʒp # and filter to only keep primes





                            share|improve this answer











                            $endgroup$




                            05AB1E, 16 12 9 bytes



                            Generates an infinite list.

                            Saved 4 bytes with Kevin Cruijssen's port of Arnaulds formula.

                            Saved another 3 bytes thanks to Grimy



                            ∞n3*4÷>ʒp


                            Try it online!



                            Explanation



                            ∞ # on the list of infinite positive integers
                            n3*4÷> # calculate (3*N^2)//4+1 for each
                            ʒp # and filter to only keep primes






                            share|improve this answer














                            share|improve this answer



                            share|improve this answer








                            edited May 14 at 15:54

























                            answered May 14 at 13:33









                            EmignaEmigna

                            49.5k534150




                            49.5k534150











                            • $begingroup$
                              You've made a typo in your explanation: "put a copy of N^2+3 on the stack" should be 3*N^2. Also, why the ) instead of ¯? Because it's easier to type? And for some reason I have the feeling the NnN‚3*¬sO‚ can be 1 byte shorter, but I'm not seeing it. A slight equal-byte alternative is Nn3*DN3*+‚. But I'm probably just seeing things that aren't there.. ;) Nice answer, so +1 from me.
                              $endgroup$
                              – Kevin Cruijssen
                              May 14 at 14:30






                            • 1




                              $begingroup$
                              I actually tried to port my answer to 05AB1E, but failed miserably. :D
                              $endgroup$
                              – Arnauld
                              May 14 at 15:09






                            • 1




                              $begingroup$
                              Actually, generating an infinite list is more convenient: 9 bytes with ∞n3*4÷>ʒp
                              $endgroup$
                              – Grimy
                              May 14 at 15:45






                            • 1




                              $begingroup$
                              OK, I'm not used to specs that contradict themselves. :-)
                              $endgroup$
                              – WGroleau
                              May 14 at 21:11






                            • 6




                              $begingroup$
                              @WGroleau I assume you've never developed software professionally then. I'm more concerned when I get specs that don't contradict themselves.
                              $endgroup$
                              – MikeTheLiar
                              May 14 at 21:29
















                            • $begingroup$
                              You've made a typo in your explanation: "put a copy of N^2+3 on the stack" should be 3*N^2. Also, why the ) instead of ¯? Because it's easier to type? And for some reason I have the feeling the NnN‚3*¬sO‚ can be 1 byte shorter, but I'm not seeing it. A slight equal-byte alternative is Nn3*DN3*+‚. But I'm probably just seeing things that aren't there.. ;) Nice answer, so +1 from me.
                              $endgroup$
                              – Kevin Cruijssen
                              May 14 at 14:30






                            • 1




                              $begingroup$
                              I actually tried to port my answer to 05AB1E, but failed miserably. :D
                              $endgroup$
                              – Arnauld
                              May 14 at 15:09






                            • 1




                              $begingroup$
                              Actually, generating an infinite list is more convenient: 9 bytes with ∞n3*4÷>ʒp
                              $endgroup$
                              – Grimy
                              May 14 at 15:45






                            • 1




                              $begingroup$
                              OK, I'm not used to specs that contradict themselves. :-)
                              $endgroup$
                              – WGroleau
                              May 14 at 21:11






                            • 6




                              $begingroup$
                              @WGroleau I assume you've never developed software professionally then. I'm more concerned when I get specs that don't contradict themselves.
                              $endgroup$
                              – MikeTheLiar
                              May 14 at 21:29















                            $begingroup$
                            You've made a typo in your explanation: "put a copy of N^2+3 on the stack" should be 3*N^2. Also, why the ) instead of ¯? Because it's easier to type? And for some reason I have the feeling the NnN‚3*¬sO‚ can be 1 byte shorter, but I'm not seeing it. A slight equal-byte alternative is Nn3*DN3*+‚. But I'm probably just seeing things that aren't there.. ;) Nice answer, so +1 from me.
                            $endgroup$
                            – Kevin Cruijssen
                            May 14 at 14:30




                            $begingroup$
                            You've made a typo in your explanation: "put a copy of N^2+3 on the stack" should be 3*N^2. Also, why the ) instead of ¯? Because it's easier to type? And for some reason I have the feeling the NnN‚3*¬sO‚ can be 1 byte shorter, but I'm not seeing it. A slight equal-byte alternative is Nn3*DN3*+‚. But I'm probably just seeing things that aren't there.. ;) Nice answer, so +1 from me.
                            $endgroup$
                            – Kevin Cruijssen
                            May 14 at 14:30




                            1




                            1




                            $begingroup$
                            I actually tried to port my answer to 05AB1E, but failed miserably. :D
                            $endgroup$
                            – Arnauld
                            May 14 at 15:09




                            $begingroup$
                            I actually tried to port my answer to 05AB1E, but failed miserably. :D
                            $endgroup$
                            – Arnauld
                            May 14 at 15:09




                            1




                            1




                            $begingroup$
                            Actually, generating an infinite list is more convenient: 9 bytes with ∞n3*4÷>ʒp
                            $endgroup$
                            – Grimy
                            May 14 at 15:45




                            $begingroup$
                            Actually, generating an infinite list is more convenient: 9 bytes with ∞n3*4÷>ʒp
                            $endgroup$
                            – Grimy
                            May 14 at 15:45




                            1




                            1




                            $begingroup$
                            OK, I'm not used to specs that contradict themselves. :-)
                            $endgroup$
                            – WGroleau
                            May 14 at 21:11




                            $begingroup$
                            OK, I'm not used to specs that contradict themselves. :-)
                            $endgroup$
                            – WGroleau
                            May 14 at 21:11




                            6




                            6




                            $begingroup$
                            @WGroleau I assume you've never developed software professionally then. I'm more concerned when I get specs that don't contradict themselves.
                            $endgroup$
                            – MikeTheLiar
                            May 14 at 21:29




                            $begingroup$
                            @WGroleau I assume you've never developed software professionally then. I'm more concerned when I get specs that don't contradict themselves.
                            $endgroup$
                            – MikeTheLiar
                            May 14 at 21:29











                            7












                            $begingroup$


                            R, 75 73 bytes





                            n=scan()
                            while(F<n)F=F+any(!(((T<-T+1)*1:4-1)/3)^.5%%1)*all(T%%(3:T-1))
                            T


                            Try it online!



                            -2 bytes by noticing that I can remove brackets if I use * instead of & (different precedence).



                            Outputs the nth Cuban prime (1-indexed).



                            It uses the fact (given in OEIS) that Cuban primes are of the form $p=1+3n^2$ or $4p=1+3n^2$ for some $n$, i.e. $n=sqrtfracacdot p-13$ is an integer for $a=1$ or $a=4$.



                            The trick is that no prime can be of the form $2p=1+3n^2$ or $3p=1+3n^2$ (*), so we can save 2 bytes by checking the formula for $ain1, 2, 3, 4$ (1:4) instead of $ain1, 4$ (c(1,4)).



                            Slightly ungolfed version of the code:



                            # F and T are implicitly initialized at 0 and 1
                            # F is number of Cuban primes found so far
                            # T is number currently being tested for being a Cuban prime
                            n = scan() # input
                            while(F<n)
                            T = T+1 # increment T
                            F = F + # increment F if
                            (!all(((T*1:4-1)/3)^.5 %% 1) # there is an integer of the form sqrt(((T*a)-1)/3)
                            & all(T%%(3:T-1))) # and T is prime (not divisible by any number between 2 and T-1)

                            T # output T


                            (*) No prime can be of the form $3p=1+3n^2$, else $1=3(p-n^2)$ would be divisible by $3$.



                            No prime other than $p=2$ (which isn't a Cuban prime) can of the form $2p=1+3n^2$: $n$ would need to be odd, i.e. $n=2k+1$. Expanding gives $2p=4+12k(k+1)$, hence $p=2+6k(k+1)$ and $p$ would be even.






                            share|improve this answer











                            $endgroup$












                            • $begingroup$
                              what about avoiding a loop by using an upper bound on the nth Cuban prime?
                              $endgroup$
                              – Xi'an
                              May 15 at 7:31










                            • $begingroup$
                              @Xi'an I thought about that, but couldn't come up with such a bound. Do you have one?
                              $endgroup$
                              – Robin Ryder
                              May 15 at 13:32















                            7












                            $begingroup$


                            R, 75 73 bytes





                            n=scan()
                            while(F<n)F=F+any(!(((T<-T+1)*1:4-1)/3)^.5%%1)*all(T%%(3:T-1))
                            T


                            Try it online!



                            -2 bytes by noticing that I can remove brackets if I use * instead of & (different precedence).



                            Outputs the nth Cuban prime (1-indexed).



                            It uses the fact (given in OEIS) that Cuban primes are of the form $p=1+3n^2$ or $4p=1+3n^2$ for some $n$, i.e. $n=sqrtfracacdot p-13$ is an integer for $a=1$ or $a=4$.



                            The trick is that no prime can be of the form $2p=1+3n^2$ or $3p=1+3n^2$ (*), so we can save 2 bytes by checking the formula for $ain1, 2, 3, 4$ (1:4) instead of $ain1, 4$ (c(1,4)).



                            Slightly ungolfed version of the code:



                            # F and T are implicitly initialized at 0 and 1
                            # F is number of Cuban primes found so far
                            # T is number currently being tested for being a Cuban prime
                            n = scan() # input
                            while(F<n)
                            T = T+1 # increment T
                            F = F + # increment F if
                            (!all(((T*1:4-1)/3)^.5 %% 1) # there is an integer of the form sqrt(((T*a)-1)/3)
                            & all(T%%(3:T-1))) # and T is prime (not divisible by any number between 2 and T-1)

                            T # output T


                            (*) No prime can be of the form $3p=1+3n^2$, else $1=3(p-n^2)$ would be divisible by $3$.



                            No prime other than $p=2$ (which isn't a Cuban prime) can of the form $2p=1+3n^2$: $n$ would need to be odd, i.e. $n=2k+1$. Expanding gives $2p=4+12k(k+1)$, hence $p=2+6k(k+1)$ and $p$ would be even.






                            share|improve this answer











                            $endgroup$












                            • $begingroup$
                              what about avoiding a loop by using an upper bound on the nth Cuban prime?
                              $endgroup$
                              – Xi'an
                              May 15 at 7:31










                            • $begingroup$
                              @Xi'an I thought about that, but couldn't come up with such a bound. Do you have one?
                              $endgroup$
                              – Robin Ryder
                              May 15 at 13:32













                            7












                            7








                            7





                            $begingroup$


                            R, 75 73 bytes





                            n=scan()
                            while(F<n)F=F+any(!(((T<-T+1)*1:4-1)/3)^.5%%1)*all(T%%(3:T-1))
                            T


                            Try it online!



                            -2 bytes by noticing that I can remove brackets if I use * instead of & (different precedence).



                            Outputs the nth Cuban prime (1-indexed).



                            It uses the fact (given in OEIS) that Cuban primes are of the form $p=1+3n^2$ or $4p=1+3n^2$ for some $n$, i.e. $n=sqrtfracacdot p-13$ is an integer for $a=1$ or $a=4$.



                            The trick is that no prime can be of the form $2p=1+3n^2$ or $3p=1+3n^2$ (*), so we can save 2 bytes by checking the formula for $ain1, 2, 3, 4$ (1:4) instead of $ain1, 4$ (c(1,4)).



                            Slightly ungolfed version of the code:



                            # F and T are implicitly initialized at 0 and 1
                            # F is number of Cuban primes found so far
                            # T is number currently being tested for being a Cuban prime
                            n = scan() # input
                            while(F<n)
                            T = T+1 # increment T
                            F = F + # increment F if
                            (!all(((T*1:4-1)/3)^.5 %% 1) # there is an integer of the form sqrt(((T*a)-1)/3)
                            & all(T%%(3:T-1))) # and T is prime (not divisible by any number between 2 and T-1)

                            T # output T


                            (*) No prime can be of the form $3p=1+3n^2$, else $1=3(p-n^2)$ would be divisible by $3$.



                            No prime other than $p=2$ (which isn't a Cuban prime) can of the form $2p=1+3n^2$: $n$ would need to be odd, i.e. $n=2k+1$. Expanding gives $2p=4+12k(k+1)$, hence $p=2+6k(k+1)$ and $p$ would be even.






                            share|improve this answer











                            $endgroup$




                            R, 75 73 bytes





                            n=scan()
                            while(F<n)F=F+any(!(((T<-T+1)*1:4-1)/3)^.5%%1)*all(T%%(3:T-1))
                            T


                            Try it online!



                            -2 bytes by noticing that I can remove brackets if I use * instead of & (different precedence).



                            Outputs the nth Cuban prime (1-indexed).



                            It uses the fact (given in OEIS) that Cuban primes are of the form $p=1+3n^2$ or $4p=1+3n^2$ for some $n$, i.e. $n=sqrtfracacdot p-13$ is an integer for $a=1$ or $a=4$.



                            The trick is that no prime can be of the form $2p=1+3n^2$ or $3p=1+3n^2$ (*), so we can save 2 bytes by checking the formula for $ain1, 2, 3, 4$ (1:4) instead of $ain1, 4$ (c(1,4)).



                            Slightly ungolfed version of the code:



                            # F and T are implicitly initialized at 0 and 1
                            # F is number of Cuban primes found so far
                            # T is number currently being tested for being a Cuban prime
                            n = scan() # input
                            while(F<n)
                            T = T+1 # increment T
                            F = F + # increment F if
                            (!all(((T*1:4-1)/3)^.5 %% 1) # there is an integer of the form sqrt(((T*a)-1)/3)
                            & all(T%%(3:T-1))) # and T is prime (not divisible by any number between 2 and T-1)

                            T # output T


                            (*) No prime can be of the form $3p=1+3n^2$, else $1=3(p-n^2)$ would be divisible by $3$.



                            No prime other than $p=2$ (which isn't a Cuban prime) can of the form $2p=1+3n^2$: $n$ would need to be odd, i.e. $n=2k+1$. Expanding gives $2p=4+12k(k+1)$, hence $p=2+6k(k+1)$ and $p$ would be even.







                            share|improve this answer














                            share|improve this answer



                            share|improve this answer








                            edited May 14 at 15:55

























                            answered May 14 at 14:32









                            Robin RyderRobin Ryder

                            1,288215




                            1,288215











                            • $begingroup$
                              what about avoiding a loop by using an upper bound on the nth Cuban prime?
                              $endgroup$
                              – Xi'an
                              May 15 at 7:31










                            • $begingroup$
                              @Xi'an I thought about that, but couldn't come up with such a bound. Do you have one?
                              $endgroup$
                              – Robin Ryder
                              May 15 at 13:32
















                            • $begingroup$
                              what about avoiding a loop by using an upper bound on the nth Cuban prime?
                              $endgroup$
                              – Xi'an
                              May 15 at 7:31










                            • $begingroup$
                              @Xi'an I thought about that, but couldn't come up with such a bound. Do you have one?
                              $endgroup$
                              – Robin Ryder
                              May 15 at 13:32















                            $begingroup$
                            what about avoiding a loop by using an upper bound on the nth Cuban prime?
                            $endgroup$
                            – Xi'an
                            May 15 at 7:31




                            $begingroup$
                            what about avoiding a loop by using an upper bound on the nth Cuban prime?
                            $endgroup$
                            – Xi'an
                            May 15 at 7:31












                            $begingroup$
                            @Xi'an I thought about that, but couldn't come up with such a bound. Do you have one?
                            $endgroup$
                            – Robin Ryder
                            May 15 at 13:32




                            $begingroup$
                            @Xi'an I thought about that, but couldn't come up with such a bound. Do you have one?
                            $endgroup$
                            – Robin Ryder
                            May 15 at 13:32











                            5












                            $begingroup$


                            Wolfram Language (Mathematica), 66 65 56 bytes



                            (f=1+⌊3#/4#⌋&;For[n=i=0,i<#,PrimeQ@f@++n&&i++];f@n)&


                            Try it online!



                            • J42161217 -1 by using ⌊ ⌋ instead of Floor[ ]



                            • attinat




                              • -1 by using ⌊3#/4#⌋ instead of ⌊3#^2/4⌋


                              • -8 for For[n=i=0,i<#,PrimeQ@f@++n&&i++] instead of n=2;i=#;While[i>0,i-=Boole@PrimeQ@f@++n]






                            share|improve this answer











                            $endgroup$








                            • 1




                              $begingroup$
                              65 bytes. Welcome to ppcg. Nice first answer! +1
                              $endgroup$
                              – J42161217
                              May 14 at 18:39










                            • $begingroup$
                              Thanks! (Long time lurker.) I couldn't quite parse your existing answer so I wrote my own and it came out a little shorter. I might do a Python one too.
                              $endgroup$
                              – speedstyle
                              May 14 at 18:57






                            • 2




                              $begingroup$
                              56 bytes
                              $endgroup$
                              – attinat
                              May 14 at 21:54










                            • $begingroup$
                              @attinat I thought Arnauld's formula only worked for n>2 so I didn't start with 0 - although as in your example it works for all n (because it starts 1 1 4 7 13 ... so the primes are 7 13 ...)
                              $endgroup$
                              – speedstyle
                              May 14 at 22:33















                            5












                            $begingroup$


                            Wolfram Language (Mathematica), 66 65 56 bytes



                            (f=1+⌊3#/4#⌋&;For[n=i=0,i<#,PrimeQ@f@++n&&i++];f@n)&


                            Try it online!



                            • J42161217 -1 by using ⌊ ⌋ instead of Floor[ ]



                            • attinat




                              • -1 by using ⌊3#/4#⌋ instead of ⌊3#^2/4⌋


                              • -8 for For[n=i=0,i<#,PrimeQ@f@++n&&i++] instead of n=2;i=#;While[i>0,i-=Boole@PrimeQ@f@++n]






                            share|improve this answer











                            $endgroup$








                            • 1




                              $begingroup$
                              65 bytes. Welcome to ppcg. Nice first answer! +1
                              $endgroup$
                              – J42161217
                              May 14 at 18:39










                            • $begingroup$
                              Thanks! (Long time lurker.) I couldn't quite parse your existing answer so I wrote my own and it came out a little shorter. I might do a Python one too.
                              $endgroup$
                              – speedstyle
                              May 14 at 18:57






                            • 2




                              $begingroup$
                              56 bytes
                              $endgroup$
                              – attinat
                              May 14 at 21:54










                            • $begingroup$
                              @attinat I thought Arnauld's formula only worked for n>2 so I didn't start with 0 - although as in your example it works for all n (because it starts 1 1 4 7 13 ... so the primes are 7 13 ...)
                              $endgroup$
                              – speedstyle
                              May 14 at 22:33













                            5












                            5








                            5





                            $begingroup$


                            Wolfram Language (Mathematica), 66 65 56 bytes



                            (f=1+⌊3#/4#⌋&;For[n=i=0,i<#,PrimeQ@f@++n&&i++];f@n)&


                            Try it online!



                            • J42161217 -1 by using ⌊ ⌋ instead of Floor[ ]



                            • attinat




                              • -1 by using ⌊3#/4#⌋ instead of ⌊3#^2/4⌋


                              • -8 for For[n=i=0,i<#,PrimeQ@f@++n&&i++] instead of n=2;i=#;While[i>0,i-=Boole@PrimeQ@f@++n]






                            share|improve this answer











                            $endgroup$




                            Wolfram Language (Mathematica), 66 65 56 bytes



                            (f=1+⌊3#/4#⌋&;For[n=i=0,i<#,PrimeQ@f@++n&&i++];f@n)&


                            Try it online!



                            • J42161217 -1 by using ⌊ ⌋ instead of Floor[ ]



                            • attinat




                              • -1 by using ⌊3#/4#⌋ instead of ⌊3#^2/4⌋


                              • -8 for For[n=i=0,i<#,PrimeQ@f@++n&&i++] instead of n=2;i=#;While[i>0,i-=Boole@PrimeQ@f@++n]







                            share|improve this answer














                            share|improve this answer



                            share|improve this answer








                            edited May 14 at 22:56

























                            answered May 14 at 18:27









                            speedstylespeedstyle

                            695




                            695







                            • 1




                              $begingroup$
                              65 bytes. Welcome to ppcg. Nice first answer! +1
                              $endgroup$
                              – J42161217
                              May 14 at 18:39










                            • $begingroup$
                              Thanks! (Long time lurker.) I couldn't quite parse your existing answer so I wrote my own and it came out a little shorter. I might do a Python one too.
                              $endgroup$
                              – speedstyle
                              May 14 at 18:57






                            • 2




                              $begingroup$
                              56 bytes
                              $endgroup$
                              – attinat
                              May 14 at 21:54










                            • $begingroup$
                              @attinat I thought Arnauld's formula only worked for n>2 so I didn't start with 0 - although as in your example it works for all n (because it starts 1 1 4 7 13 ... so the primes are 7 13 ...)
                              $endgroup$
                              – speedstyle
                              May 14 at 22:33












                            • 1




                              $begingroup$
                              65 bytes. Welcome to ppcg. Nice first answer! +1
                              $endgroup$
                              – J42161217
                              May 14 at 18:39










                            • $begingroup$
                              Thanks! (Long time lurker.) I couldn't quite parse your existing answer so I wrote my own and it came out a little shorter. I might do a Python one too.
                              $endgroup$
                              – speedstyle
                              May 14 at 18:57






                            • 2




                              $begingroup$
                              56 bytes
                              $endgroup$
                              – attinat
                              May 14 at 21:54










                            • $begingroup$
                              @attinat I thought Arnauld's formula only worked for n>2 so I didn't start with 0 - although as in your example it works for all n (because it starts 1 1 4 7 13 ... so the primes are 7 13 ...)
                              $endgroup$
                              – speedstyle
                              May 14 at 22:33







                            1




                            1




                            $begingroup$
                            65 bytes. Welcome to ppcg. Nice first answer! +1
                            $endgroup$
                            – J42161217
                            May 14 at 18:39




                            $begingroup$
                            65 bytes. Welcome to ppcg. Nice first answer! +1
                            $endgroup$
                            – J42161217
                            May 14 at 18:39












                            $begingroup$
                            Thanks! (Long time lurker.) I couldn't quite parse your existing answer so I wrote my own and it came out a little shorter. I might do a Python one too.
                            $endgroup$
                            – speedstyle
                            May 14 at 18:57




                            $begingroup$
                            Thanks! (Long time lurker.) I couldn't quite parse your existing answer so I wrote my own and it came out a little shorter. I might do a Python one too.
                            $endgroup$
                            – speedstyle
                            May 14 at 18:57




                            2




                            2




                            $begingroup$
                            56 bytes
                            $endgroup$
                            – attinat
                            May 14 at 21:54




                            $begingroup$
                            56 bytes
                            $endgroup$
                            – attinat
                            May 14 at 21:54












                            $begingroup$
                            @attinat I thought Arnauld's formula only worked for n>2 so I didn't start with 0 - although as in your example it works for all n (because it starts 1 1 4 7 13 ... so the primes are 7 13 ...)
                            $endgroup$
                            – speedstyle
                            May 14 at 22:33




                            $begingroup$
                            @attinat I thought Arnauld's formula only worked for n>2 so I didn't start with 0 - although as in your example it works for all n (because it starts 1 1 4 7 13 ... so the primes are 7 13 ...)
                            $endgroup$
                            – speedstyle
                            May 14 at 22:33











                            3












                            $begingroup$

                            Java 8, 94 88 86 84 bytes





                            v->for(int i=3,n,x;;System.out.print(x<1?++n+" ":""))for(x=n=i*i++*3/4;~n%x--<0;);


                            -6 bytes by using the Java prime-checker of @SaraJ, so make sure to upvote her!

                            -2 bytes thanks to @OlivierGrégoire. Since the first number we check is 7, we can drop the trailing %n from Sara's prime-checker, which is to terminate the loop for n=1.

                            -2 bytes thanks to @OlivierGrégoire by porting @Arnauld's answer.



                            Outputs space-delimited indefinitely.



                            Try it online.



                            Explanation (of the old 86 bytes version): TODO: Update explanation



                            Uses the formula of @Arnauld's JavaScript answer: $p_n=leftlfloorfrac3n^24rightrfloor+1,;nge3$.



                            v-> // Method with empty unused parameter and no return-type
                            for(int i=3, // Loop-integer, starting at 3
                            n,x // Temp integers
                            ; // Loop indefinitely:
                            ; // After every iteration:
                            System.out.print( // Print:
                            n==x? // If `n` equals `x`, which means `n` is a prime:
                            n+" " // Print `n` with a space delimiter
                            : // Else:
                            "")) // Print nothing
                            for(n=i*i++*3/4+1, // Set `n` to `(3*i^2)//4+1
                            // (and increase `i` by 1 afterwards with `i++`)
                            x=1; // Set `x` to 1
                            n%++x // Loop as long as `n` modulo `x+1`
                            // (after we've first increased `x` by 1 with `++x`)
                            >0;); // is not 0 yet
                            // (if `n` is equal to `x`, it means it's a prime)





                            share|improve this answer











                            $endgroup$












                            • $begingroup$
                              I don't really think it's feasible, but another way of finding the cuban primes uses this formula: v->for(int n=7,i=3,p,x,d,r=0;;i+=++r%2*3,n+=i,System.out.print(x>1?x+" ":""))for(x=n,d=1;++d<n;x=x%d<1?0:n);, maybe someone can use this to golf? I couldn't.
                              $endgroup$
                              – Olivier Grégoire
                              May 16 at 9:03






                            • 1




                              $begingroup$
                              @OlivierGrégoire You can golf yours a bit more by removing the unused ,p and changing i+=++r%2*3,n+=i to n+=i+=++r%2*3, but then I'll still end up at 106 bytes. Using Java 11's String#repeat with prime-regex is 105 bytes: v->(..+?)\1+"))System.out.println(n);.
                              $endgroup$
                              – Kevin Cruijssen
                              May 16 at 9:40











                            • $begingroup$
                              Yeah, I guessed it wasn't much golfable despite my (now obvious) mistakes. Thanks for giving it a ride ;)
                              $endgroup$
                              – Olivier Grégoire
                              May 16 at 14:02










                            • $begingroup$
                              @OlivierGrégoire Maybe also good to know for you, but there is apparently a shorter prime-check loop in Java. See my edit and SaraJ's prime-check answer.
                              $endgroup$
                              – Kevin Cruijssen
                              May 16 at 14:30











                            • $begingroup$
                              I might be wrong, but the last %n isn't required, is it?
                              $endgroup$
                              – Olivier Grégoire
                              May 16 at 14:44















                            3












                            $begingroup$

                            Java 8, 94 88 86 84 bytes





                            v->for(int i=3,n,x;;System.out.print(x<1?++n+" ":""))for(x=n=i*i++*3/4;~n%x--<0;);


                            -6 bytes by using the Java prime-checker of @SaraJ, so make sure to upvote her!

                            -2 bytes thanks to @OlivierGrégoire. Since the first number we check is 7, we can drop the trailing %n from Sara's prime-checker, which is to terminate the loop for n=1.

                            -2 bytes thanks to @OlivierGrégoire by porting @Arnauld's answer.



                            Outputs space-delimited indefinitely.



                            Try it online.



                            Explanation (of the old 86 bytes version): TODO: Update explanation



                            Uses the formula of @Arnauld's JavaScript answer: $p_n=leftlfloorfrac3n^24rightrfloor+1,;nge3$.



                            v-> // Method with empty unused parameter and no return-type
                            for(int i=3, // Loop-integer, starting at 3
                            n,x // Temp integers
                            ; // Loop indefinitely:
                            ; // After every iteration:
                            System.out.print( // Print:
                            n==x? // If `n` equals `x`, which means `n` is a prime:
                            n+" " // Print `n` with a space delimiter
                            : // Else:
                            "")) // Print nothing
                            for(n=i*i++*3/4+1, // Set `n` to `(3*i^2)//4+1
                            // (and increase `i` by 1 afterwards with `i++`)
                            x=1; // Set `x` to 1
                            n%++x // Loop as long as `n` modulo `x+1`
                            // (after we've first increased `x` by 1 with `++x`)
                            >0;); // is not 0 yet
                            // (if `n` is equal to `x`, it means it's a prime)





                            share|improve this answer











                            $endgroup$












                            • $begingroup$
                              I don't really think it's feasible, but another way of finding the cuban primes uses this formula: v->for(int n=7,i=3,p,x,d,r=0;;i+=++r%2*3,n+=i,System.out.print(x>1?x+" ":""))for(x=n,d=1;++d<n;x=x%d<1?0:n);, maybe someone can use this to golf? I couldn't.
                              $endgroup$
                              – Olivier Grégoire
                              May 16 at 9:03






                            • 1




                              $begingroup$
                              @OlivierGrégoire You can golf yours a bit more by removing the unused ,p and changing i+=++r%2*3,n+=i to n+=i+=++r%2*3, but then I'll still end up at 106 bytes. Using Java 11's String#repeat with prime-regex is 105 bytes: v->(..+?)\1+"))System.out.println(n);.
                              $endgroup$
                              – Kevin Cruijssen
                              May 16 at 9:40











                            • $begingroup$
                              Yeah, I guessed it wasn't much golfable despite my (now obvious) mistakes. Thanks for giving it a ride ;)
                              $endgroup$
                              – Olivier Grégoire
                              May 16 at 14:02










                            • $begingroup$
                              @OlivierGrégoire Maybe also good to know for you, but there is apparently a shorter prime-check loop in Java. See my edit and SaraJ's prime-check answer.
                              $endgroup$
                              – Kevin Cruijssen
                              May 16 at 14:30











                            • $begingroup$
                              I might be wrong, but the last %n isn't required, is it?
                              $endgroup$
                              – Olivier Grégoire
                              May 16 at 14:44













                            3












                            3








                            3





                            $begingroup$

                            Java 8, 94 88 86 84 bytes





                            v->for(int i=3,n,x;;System.out.print(x<1?++n+" ":""))for(x=n=i*i++*3/4;~n%x--<0;);


                            -6 bytes by using the Java prime-checker of @SaraJ, so make sure to upvote her!

                            -2 bytes thanks to @OlivierGrégoire. Since the first number we check is 7, we can drop the trailing %n from Sara's prime-checker, which is to terminate the loop for n=1.

                            -2 bytes thanks to @OlivierGrégoire by porting @Arnauld's answer.



                            Outputs space-delimited indefinitely.



                            Try it online.



                            Explanation (of the old 86 bytes version): TODO: Update explanation



                            Uses the formula of @Arnauld's JavaScript answer: $p_n=leftlfloorfrac3n^24rightrfloor+1,;nge3$.



                            v-> // Method with empty unused parameter and no return-type
                            for(int i=3, // Loop-integer, starting at 3
                            n,x // Temp integers
                            ; // Loop indefinitely:
                            ; // After every iteration:
                            System.out.print( // Print:
                            n==x? // If `n` equals `x`, which means `n` is a prime:
                            n+" " // Print `n` with a space delimiter
                            : // Else:
                            "")) // Print nothing
                            for(n=i*i++*3/4+1, // Set `n` to `(3*i^2)//4+1
                            // (and increase `i` by 1 afterwards with `i++`)
                            x=1; // Set `x` to 1
                            n%++x // Loop as long as `n` modulo `x+1`
                            // (after we've first increased `x` by 1 with `++x`)
                            >0;); // is not 0 yet
                            // (if `n` is equal to `x`, it means it's a prime)





                            share|improve this answer











                            $endgroup$



                            Java 8, 94 88 86 84 bytes





                            v->for(int i=3,n,x;;System.out.print(x<1?++n+" ":""))for(x=n=i*i++*3/4;~n%x--<0;);


                            -6 bytes by using the Java prime-checker of @SaraJ, so make sure to upvote her!

                            -2 bytes thanks to @OlivierGrégoire. Since the first number we check is 7, we can drop the trailing %n from Sara's prime-checker, which is to terminate the loop for n=1.

                            -2 bytes thanks to @OlivierGrégoire by porting @Arnauld's answer.



                            Outputs space-delimited indefinitely.



                            Try it online.



                            Explanation (of the old 86 bytes version): TODO: Update explanation



                            Uses the formula of @Arnauld's JavaScript answer: $p_n=leftlfloorfrac3n^24rightrfloor+1,;nge3$.



                            v-> // Method with empty unused parameter and no return-type
                            for(int i=3, // Loop-integer, starting at 3
                            n,x // Temp integers
                            ; // Loop indefinitely:
                            ; // After every iteration:
                            System.out.print( // Print:
                            n==x? // If `n` equals `x`, which means `n` is a prime:
                            n+" " // Print `n` with a space delimiter
                            : // Else:
                            "")) // Print nothing
                            for(n=i*i++*3/4+1, // Set `n` to `(3*i^2)//4+1
                            // (and increase `i` by 1 afterwards with `i++`)
                            x=1; // Set `x` to 1
                            n%++x // Loop as long as `n` modulo `x+1`
                            // (after we've first increased `x` by 1 with `++x`)
                            >0;); // is not 0 yet
                            // (if `n` is equal to `x`, it means it's a prime)






                            share|improve this answer














                            share|improve this answer



                            share|improve this answer








                            edited May 16 at 15:43

























                            answered May 15 at 6:48









                            Kevin CruijssenKevin Cruijssen

                            44.9k576225




                            44.9k576225











                            • $begingroup$
                              I don't really think it's feasible, but another way of finding the cuban primes uses this formula: v->for(int n=7,i=3,p,x,d,r=0;;i+=++r%2*3,n+=i,System.out.print(x>1?x+" ":""))for(x=n,d=1;++d<n;x=x%d<1?0:n);, maybe someone can use this to golf? I couldn't.
                              $endgroup$
                              – Olivier Grégoire
                              May 16 at 9:03






                            • 1




                              $begingroup$
                              @OlivierGrégoire You can golf yours a bit more by removing the unused ,p and changing i+=++r%2*3,n+=i to n+=i+=++r%2*3, but then I'll still end up at 106 bytes. Using Java 11's String#repeat with prime-regex is 105 bytes: v->(..+?)\1+"))System.out.println(n);.
                              $endgroup$
                              – Kevin Cruijssen
                              May 16 at 9:40











                            • $begingroup$
                              Yeah, I guessed it wasn't much golfable despite my (now obvious) mistakes. Thanks for giving it a ride ;)
                              $endgroup$
                              – Olivier Grégoire
                              May 16 at 14:02










                            • $begingroup$
                              @OlivierGrégoire Maybe also good to know for you, but there is apparently a shorter prime-check loop in Java. See my edit and SaraJ's prime-check answer.
                              $endgroup$
                              – Kevin Cruijssen
                              May 16 at 14:30











                            • $begingroup$
                              I might be wrong, but the last %n isn't required, is it?
                              $endgroup$
                              – Olivier Grégoire
                              May 16 at 14:44
















                            • $begingroup$
                              I don't really think it's feasible, but another way of finding the cuban primes uses this formula: v->for(int n=7,i=3,p,x,d,r=0;;i+=++r%2*3,n+=i,System.out.print(x>1?x+" ":""))for(x=n,d=1;++d<n;x=x%d<1?0:n);, maybe someone can use this to golf? I couldn't.
                              $endgroup$
                              – Olivier Grégoire
                              May 16 at 9:03






                            • 1




                              $begingroup$
                              @OlivierGrégoire You can golf yours a bit more by removing the unused ,p and changing i+=++r%2*3,n+=i to n+=i+=++r%2*3, but then I'll still end up at 106 bytes. Using Java 11's String#repeat with prime-regex is 105 bytes: v->(..+?)\1+"))System.out.println(n);.
                              $endgroup$
                              – Kevin Cruijssen
                              May 16 at 9:40











                            • $begingroup$
                              Yeah, I guessed it wasn't much golfable despite my (now obvious) mistakes. Thanks for giving it a ride ;)
                              $endgroup$
                              – Olivier Grégoire
                              May 16 at 14:02










                            • $begingroup$
                              @OlivierGrégoire Maybe also good to know for you, but there is apparently a shorter prime-check loop in Java. See my edit and SaraJ's prime-check answer.
                              $endgroup$
                              – Kevin Cruijssen
                              May 16 at 14:30











                            • $begingroup$
                              I might be wrong, but the last %n isn't required, is it?
                              $endgroup$
                              – Olivier Grégoire
                              May 16 at 14:44















                            $begingroup$
                            I don't really think it's feasible, but another way of finding the cuban primes uses this formula: v->for(int n=7,i=3,p,x,d,r=0;;i+=++r%2*3,n+=i,System.out.print(x>1?x+" ":""))for(x=n,d=1;++d<n;x=x%d<1?0:n);, maybe someone can use this to golf? I couldn't.
                            $endgroup$
                            – Olivier Grégoire
                            May 16 at 9:03




                            $begingroup$
                            I don't really think it's feasible, but another way of finding the cuban primes uses this formula: v->for(int n=7,i=3,p,x,d,r=0;;i+=++r%2*3,n+=i,System.out.print(x>1?x+" ":""))for(x=n,d=1;++d<n;x=x%d<1?0:n);, maybe someone can use this to golf? I couldn't.
                            $endgroup$
                            – Olivier Grégoire
                            May 16 at 9:03




                            1




                            1




                            $begingroup$
                            @OlivierGrégoire You can golf yours a bit more by removing the unused ,p and changing i+=++r%2*3,n+=i to n+=i+=++r%2*3, but then I'll still end up at 106 bytes. Using Java 11's String#repeat with prime-regex is 105 bytes: v->(..+?)\1+"))System.out.println(n);.
                            $endgroup$
                            – Kevin Cruijssen
                            May 16 at 9:40





                            $begingroup$
                            @OlivierGrégoire You can golf yours a bit more by removing the unused ,p and changing i+=++r%2*3,n+=i to n+=i+=++r%2*3, but then I'll still end up at 106 bytes. Using Java 11's String#repeat with prime-regex is 105 bytes: v->(..+?)\1+"))System.out.println(n);.
                            $endgroup$
                            – Kevin Cruijssen
                            May 16 at 9:40













                            $begingroup$
                            Yeah, I guessed it wasn't much golfable despite my (now obvious) mistakes. Thanks for giving it a ride ;)
                            $endgroup$
                            – Olivier Grégoire
                            May 16 at 14:02




                            $begingroup$
                            Yeah, I guessed it wasn't much golfable despite my (now obvious) mistakes. Thanks for giving it a ride ;)
                            $endgroup$
                            – Olivier Grégoire
                            May 16 at 14:02












                            $begingroup$
                            @OlivierGrégoire Maybe also good to know for you, but there is apparently a shorter prime-check loop in Java. See my edit and SaraJ's prime-check answer.
                            $endgroup$
                            – Kevin Cruijssen
                            May 16 at 14:30





                            $begingroup$
                            @OlivierGrégoire Maybe also good to know for you, but there is apparently a shorter prime-check loop in Java. See my edit and SaraJ's prime-check answer.
                            $endgroup$
                            – Kevin Cruijssen
                            May 16 at 14:30













                            $begingroup$
                            I might be wrong, but the last %n isn't required, is it?
                            $endgroup$
                            – Olivier Grégoire
                            May 16 at 14:44




                            $begingroup$
                            I might be wrong, but the last %n isn't required, is it?
                            $endgroup$
                            – Olivier Grégoire
                            May 16 at 14:44











                            2












                            $begingroup$


                            Wolfram Language (Mathematica), 83 bytes



                            (t=1;While[Length[l=Select[Join@@Array[(v=3#^2+1)+3#,v&,t++],PrimeQ]]<#];Sort@l)&


                            Try it online!






                            share|improve this answer











                            $endgroup$

















                              2












                              $begingroup$


                              Wolfram Language (Mathematica), 83 bytes



                              (t=1;While[Length[l=Select[Join@@Array[(v=3#^2+1)+3#,v&,t++],PrimeQ]]<#];Sort@l)&


                              Try it online!






                              share|improve this answer











                              $endgroup$















                                2












                                2








                                2





                                $begingroup$


                                Wolfram Language (Mathematica), 83 bytes



                                (t=1;While[Length[l=Select[Join@@Array[(v=3#^2+1)+3#,v&,t++],PrimeQ]]<#];Sort@l)&


                                Try it online!






                                share|improve this answer











                                $endgroup$




                                Wolfram Language (Mathematica), 83 bytes



                                (t=1;While[Length[l=Select[Join@@Array[(v=3#^2+1)+3#,v&,t++],PrimeQ]]<#];Sort@l)&


                                Try it online!







                                share|improve this answer














                                share|improve this answer



                                share|improve this answer








                                edited May 14 at 14:40

























                                answered May 14 at 13:31









                                J42161217J42161217

                                15.1k21457




                                15.1k21457





















                                    2












                                    $begingroup$


                                    Jelly, 12 bytes



                                    ²×3:4‘
                                    ÇẒ$#Ç


                                    Try it online!



                                    Based on @Arnauld’s method. Takes n on stdin and returns that many Cuban primes.






                                    share|improve this answer









                                    $endgroup$

















                                      2












                                      $begingroup$


                                      Jelly, 12 bytes



                                      ²×3:4‘
                                      ÇẒ$#Ç


                                      Try it online!



                                      Based on @Arnauld’s method. Takes n on stdin and returns that many Cuban primes.






                                      share|improve this answer









                                      $endgroup$















                                        2












                                        2








                                        2





                                        $begingroup$


                                        Jelly, 12 bytes



                                        ²×3:4‘
                                        ÇẒ$#Ç


                                        Try it online!



                                        Based on @Arnauld’s method. Takes n on stdin and returns that many Cuban primes.






                                        share|improve this answer









                                        $endgroup$




                                        Jelly, 12 bytes



                                        ²×3:4‘
                                        ÇẒ$#Ç


                                        Try it online!



                                        Based on @Arnauld’s method. Takes n on stdin and returns that many Cuban primes.







                                        share|improve this answer












                                        share|improve this answer



                                        share|improve this answer










                                        answered May 14 at 19:11









                                        Nick KennedyNick Kennedy

                                        2,56469




                                        2,56469





















                                            1












                                            $begingroup$


                                            Wolfram Language (Mathematica), 83 bytes



                                            This solution will output the n-th Cuban prime with the added benefits of being fast and remembering all previous results in the symbol f.



                                            (d:=1+3y(c=1+y)+3b c;e:=If[PrimeQ@d,n++;f@n=d];For[n=y=b=0,n<#,e;b=1-b;e,y++];f@#)&


                                            Try it online!






                                            share|improve this answer









                                            $endgroup$

















                                              1












                                              $begingroup$


                                              Wolfram Language (Mathematica), 83 bytes



                                              This solution will output the n-th Cuban prime with the added benefits of being fast and remembering all previous results in the symbol f.



                                              (d:=1+3y(c=1+y)+3b c;e:=If[PrimeQ@d,n++;f@n=d];For[n=y=b=0,n<#,e;b=1-b;e,y++];f@#)&


                                              Try it online!






                                              share|improve this answer









                                              $endgroup$















                                                1












                                                1








                                                1





                                                $begingroup$


                                                Wolfram Language (Mathematica), 83 bytes



                                                This solution will output the n-th Cuban prime with the added benefits of being fast and remembering all previous results in the symbol f.



                                                (d:=1+3y(c=1+y)+3b c;e:=If[PrimeQ@d,n++;f@n=d];For[n=y=b=0,n<#,e;b=1-b;e,y++];f@#)&


                                                Try it online!






                                                share|improve this answer









                                                $endgroup$




                                                Wolfram Language (Mathematica), 83 bytes



                                                This solution will output the n-th Cuban prime with the added benefits of being fast and remembering all previous results in the symbol f.



                                                (d:=1+3y(c=1+y)+3b c;e:=If[PrimeQ@d,n++;f@n=d];For[n=y=b=0,n<#,e;b=1-b;e,y++];f@#)&


                                                Try it online!







                                                share|improve this answer












                                                share|improve this answer



                                                share|improve this answer










                                                answered May 14 at 18:21









                                                Kelly LowderKelly Lowder

                                                3,050417




                                                3,050417





















                                                    1












                                                    $begingroup$


                                                    Whitespace, 180 bytes



                                                    [S S S T S N
                                                    _Push_2][S N
                                                    S _Duplicate][N
                                                    S S N
                                                    _Create_Label_OUTER_LOOP][S N
                                                    N
                                                    _Discard_top_stack][S S S T N
                                                    _Push_1][T S S S _Add][S N
                                                    S _Duplicate][S N
                                                    S _Duplicate][T S S N
                                                    _Multiply][S S S T T N
                                                    _Push_3][T S S N
                                                    _Multiply][S S S T S S N
                                                    _Push_4][T S T S _Integer_divide][S S S T N
                                                    _Push_1][T S S S _Add][S S S T N
                                                    _Push_1][S N
                                                    S _Duplicate_1][N
                                                    S S S N
                                                    _Create_Label_INNER_LOOP][S N
                                                    N
                                                    _Discard_top_stack][S S S T N
                                                    _Push_1][T S S S _Add][S N
                                                    S _Duplicate][S N
                                                    S _Duplicate][S T S S T T N
                                                    _Copy_0-based_3rd][T S S T _Subtract][N
                                                    T S T N
                                                    _Jump_to_Label_PRINT_if_0][S T S S T S N
                                                    _Copy_0-based_2nd][S N
                                                    T _Swap_top_two][T S T T _Modulo][S N
                                                    S _Duplicate][N
                                                    T S S S N
                                                    _Jump_to_Label_FALSE_if_0][N
                                                    S N
                                                    S N
                                                    _Jump_to_Label_INNER_LOOP][N
                                                    S S T N
                                                    _Create_Label_PRINT][T N
                                                    S T _Print_as_integer][S S S T S T S N
                                                    _Push_10_(newline)][T N
                                                    S S _Print_as_character][S N
                                                    S _Duplicate][N
                                                    S S S S N
                                                    _Create_Label_FALSE][S N
                                                    N
                                                    _Discard_top_stack][S N
                                                    N
                                                    _Discard_top_stack][N
                                                    S N
                                                    N
                                                    _Jump_to_Label_OUTER_LOOP]


                                                    Letters S (space), T (tab), and N (new-line) added as highlighting only.
                                                    [..._some_action] added as explanation only.



                                                    Outputs newline-delimited indefinitely.



                                                    Try it online (with raw spaces, tabs, and new-lines only).



                                                    Explanation in pseudo-code:



                                                    Port of my Java 8 answer, which also uses the formula from @Arnauld's JavaScript answer: $p_n=leftlfloorfrac3n^24rightrfloor+1,;nge3$.



                                                    Integer i = 2
                                                    Start OUTER_LOOP:
                                                    i = i + 1
                                                    Integer n = i*i*3//4+1
                                                    Integer x = 1
                                                    Start INNER_LOOP:
                                                    x = x + 1
                                                    If(x == n):
                                                    Call function PRINT
                                                    If(n % x == 0):
                                                    Go to next iteration of OUTER_LOOP
                                                    Go to next iteration of INNER_LOOP

                                                    function PRINT:
                                                    Print integer n
                                                    Print character 'n'
                                                    Go to next iteration of OUTER_LOOP





                                                    share|improve this answer









                                                    $endgroup$

















                                                      1












                                                      $begingroup$


                                                      Whitespace, 180 bytes



                                                      [S S S T S N
                                                      _Push_2][S N
                                                      S _Duplicate][N
                                                      S S N
                                                      _Create_Label_OUTER_LOOP][S N
                                                      N
                                                      _Discard_top_stack][S S S T N
                                                      _Push_1][T S S S _Add][S N
                                                      S _Duplicate][S N
                                                      S _Duplicate][T S S N
                                                      _Multiply][S S S T T N
                                                      _Push_3][T S S N
                                                      _Multiply][S S S T S S N
                                                      _Push_4][T S T S _Integer_divide][S S S T N
                                                      _Push_1][T S S S _Add][S S S T N
                                                      _Push_1][S N
                                                      S _Duplicate_1][N
                                                      S S S N
                                                      _Create_Label_INNER_LOOP][S N
                                                      N
                                                      _Discard_top_stack][S S S T N
                                                      _Push_1][T S S S _Add][S N
                                                      S _Duplicate][S N
                                                      S _Duplicate][S T S S T T N
                                                      _Copy_0-based_3rd][T S S T _Subtract][N
                                                      T S T N
                                                      _Jump_to_Label_PRINT_if_0][S T S S T S N
                                                      _Copy_0-based_2nd][S N
                                                      T _Swap_top_two][T S T T _Modulo][S N
                                                      S _Duplicate][N
                                                      T S S S N
                                                      _Jump_to_Label_FALSE_if_0][N
                                                      S N
                                                      S N
                                                      _Jump_to_Label_INNER_LOOP][N
                                                      S S T N
                                                      _Create_Label_PRINT][T N
                                                      S T _Print_as_integer][S S S T S T S N
                                                      _Push_10_(newline)][T N
                                                      S S _Print_as_character][S N
                                                      S _Duplicate][N
                                                      S S S S N
                                                      _Create_Label_FALSE][S N
                                                      N
                                                      _Discard_top_stack][S N
                                                      N
                                                      _Discard_top_stack][N
                                                      S N
                                                      N
                                                      _Jump_to_Label_OUTER_LOOP]


                                                      Letters S (space), T (tab), and N (new-line) added as highlighting only.
                                                      [..._some_action] added as explanation only.



                                                      Outputs newline-delimited indefinitely.



                                                      Try it online (with raw spaces, tabs, and new-lines only).



                                                      Explanation in pseudo-code:



                                                      Port of my Java 8 answer, which also uses the formula from @Arnauld's JavaScript answer: $p_n=leftlfloorfrac3n^24rightrfloor+1,;nge3$.



                                                      Integer i = 2
                                                      Start OUTER_LOOP:
                                                      i = i + 1
                                                      Integer n = i*i*3//4+1
                                                      Integer x = 1
                                                      Start INNER_LOOP:
                                                      x = x + 1
                                                      If(x == n):
                                                      Call function PRINT
                                                      If(n % x == 0):
                                                      Go to next iteration of OUTER_LOOP
                                                      Go to next iteration of INNER_LOOP

                                                      function PRINT:
                                                      Print integer n
                                                      Print character 'n'
                                                      Go to next iteration of OUTER_LOOP





                                                      share|improve this answer









                                                      $endgroup$















                                                        1












                                                        1








                                                        1





                                                        $begingroup$


                                                        Whitespace, 180 bytes



                                                        [S S S T S N
                                                        _Push_2][S N
                                                        S _Duplicate][N
                                                        S S N
                                                        _Create_Label_OUTER_LOOP][S N
                                                        N
                                                        _Discard_top_stack][S S S T N
                                                        _Push_1][T S S S _Add][S N
                                                        S _Duplicate][S N
                                                        S _Duplicate][T S S N
                                                        _Multiply][S S S T T N
                                                        _Push_3][T S S N
                                                        _Multiply][S S S T S S N
                                                        _Push_4][T S T S _Integer_divide][S S S T N
                                                        _Push_1][T S S S _Add][S S S T N
                                                        _Push_1][S N
                                                        S _Duplicate_1][N
                                                        S S S N
                                                        _Create_Label_INNER_LOOP][S N
                                                        N
                                                        _Discard_top_stack][S S S T N
                                                        _Push_1][T S S S _Add][S N
                                                        S _Duplicate][S N
                                                        S _Duplicate][S T S S T T N
                                                        _Copy_0-based_3rd][T S S T _Subtract][N
                                                        T S T N
                                                        _Jump_to_Label_PRINT_if_0][S T S S T S N
                                                        _Copy_0-based_2nd][S N
                                                        T _Swap_top_two][T S T T _Modulo][S N
                                                        S _Duplicate][N
                                                        T S S S N
                                                        _Jump_to_Label_FALSE_if_0][N
                                                        S N
                                                        S N
                                                        _Jump_to_Label_INNER_LOOP][N
                                                        S S T N
                                                        _Create_Label_PRINT][T N
                                                        S T _Print_as_integer][S S S T S T S N
                                                        _Push_10_(newline)][T N
                                                        S S _Print_as_character][S N
                                                        S _Duplicate][N
                                                        S S S S N
                                                        _Create_Label_FALSE][S N
                                                        N
                                                        _Discard_top_stack][S N
                                                        N
                                                        _Discard_top_stack][N
                                                        S N
                                                        N
                                                        _Jump_to_Label_OUTER_LOOP]


                                                        Letters S (space), T (tab), and N (new-line) added as highlighting only.
                                                        [..._some_action] added as explanation only.



                                                        Outputs newline-delimited indefinitely.



                                                        Try it online (with raw spaces, tabs, and new-lines only).



                                                        Explanation in pseudo-code:



                                                        Port of my Java 8 answer, which also uses the formula from @Arnauld's JavaScript answer: $p_n=leftlfloorfrac3n^24rightrfloor+1,;nge3$.



                                                        Integer i = 2
                                                        Start OUTER_LOOP:
                                                        i = i + 1
                                                        Integer n = i*i*3//4+1
                                                        Integer x = 1
                                                        Start INNER_LOOP:
                                                        x = x + 1
                                                        If(x == n):
                                                        Call function PRINT
                                                        If(n % x == 0):
                                                        Go to next iteration of OUTER_LOOP
                                                        Go to next iteration of INNER_LOOP

                                                        function PRINT:
                                                        Print integer n
                                                        Print character 'n'
                                                        Go to next iteration of OUTER_LOOP





                                                        share|improve this answer









                                                        $endgroup$




                                                        Whitespace, 180 bytes



                                                        [S S S T S N
                                                        _Push_2][S N
                                                        S _Duplicate][N
                                                        S S N
                                                        _Create_Label_OUTER_LOOP][S N
                                                        N
                                                        _Discard_top_stack][S S S T N
                                                        _Push_1][T S S S _Add][S N
                                                        S _Duplicate][S N
                                                        S _Duplicate][T S S N
                                                        _Multiply][S S S T T N
                                                        _Push_3][T S S N
                                                        _Multiply][S S S T S S N
                                                        _Push_4][T S T S _Integer_divide][S S S T N
                                                        _Push_1][T S S S _Add][S S S T N
                                                        _Push_1][S N
                                                        S _Duplicate_1][N
                                                        S S S N
                                                        _Create_Label_INNER_LOOP][S N
                                                        N
                                                        _Discard_top_stack][S S S T N
                                                        _Push_1][T S S S _Add][S N
                                                        S _Duplicate][S N
                                                        S _Duplicate][S T S S T T N
                                                        _Copy_0-based_3rd][T S S T _Subtract][N
                                                        T S T N
                                                        _Jump_to_Label_PRINT_if_0][S T S S T S N
                                                        _Copy_0-based_2nd][S N
                                                        T _Swap_top_two][T S T T _Modulo][S N
                                                        S _Duplicate][N
                                                        T S S S N
                                                        _Jump_to_Label_FALSE_if_0][N
                                                        S N
                                                        S N
                                                        _Jump_to_Label_INNER_LOOP][N
                                                        S S T N
                                                        _Create_Label_PRINT][T N
                                                        S T _Print_as_integer][S S S T S T S N
                                                        _Push_10_(newline)][T N
                                                        S S _Print_as_character][S N
                                                        S _Duplicate][N
                                                        S S S S N
                                                        _Create_Label_FALSE][S N
                                                        N
                                                        _Discard_top_stack][S N
                                                        N
                                                        _Discard_top_stack][N
                                                        S N
                                                        N
                                                        _Jump_to_Label_OUTER_LOOP]


                                                        Letters S (space), T (tab), and N (new-line) added as highlighting only.
                                                        [..._some_action] added as explanation only.



                                                        Outputs newline-delimited indefinitely.



                                                        Try it online (with raw spaces, tabs, and new-lines only).



                                                        Explanation in pseudo-code:



                                                        Port of my Java 8 answer, which also uses the formula from @Arnauld's JavaScript answer: $p_n=leftlfloorfrac3n^24rightrfloor+1,;nge3$.



                                                        Integer i = 2
                                                        Start OUTER_LOOP:
                                                        i = i + 1
                                                        Integer n = i*i*3//4+1
                                                        Integer x = 1
                                                        Start INNER_LOOP:
                                                        x = x + 1
                                                        If(x == n):
                                                        Call function PRINT
                                                        If(n % x == 0):
                                                        Go to next iteration of OUTER_LOOP
                                                        Go to next iteration of INNER_LOOP

                                                        function PRINT:
                                                        Print integer n
                                                        Print character 'n'
                                                        Go to next iteration of OUTER_LOOP






                                                        share|improve this answer












                                                        share|improve this answer



                                                        share|improve this answer










                                                        answered May 15 at 8:01









                                                        Kevin CruijssenKevin Cruijssen

                                                        44.9k576225




                                                        44.9k576225





















                                                            1












                                                            $begingroup$


                                                            Python 3, 110 108 102 bytes



                                                            Similar method to my Mathematica answer (i.e. isPrime(1+⌊¾n²⌋) else n++)
                                                            using this golfed prime checker and returning an anonymous infinite generator





                                                            from itertools import*
                                                            (x for x in map(lambda n:1+3*n**2//4,count(2)) if all(x%j for j in range(2,x)))


                                                            Try it online!




                                                            • mypetlion -2 because arguably anonymous generators are more allowed than named ones


                                                            • -6 by starting count at 2 +1 so that the and x>1 in the prime checker I borrowed is unnecessary -7





                                                            share|improve this answer











                                                            $endgroup$












                                                            • $begingroup$
                                                              The answer going into a variable is usually not considered a valid form of "output". Could you rework your answer so that the result is either output to stdout or returned by a function?
                                                              $endgroup$
                                                              – mypetlion
                                                              May 14 at 23:01






                                                            • 1




                                                              $begingroup$
                                                              since anonymous functions are allowed, and the challenge explicitly allows an infinite generator, I've removed g=. I had only included it in the first place because it allowed a quick visual on TIO with print(next(g) for i in range(52)).
                                                              $endgroup$
                                                              – speedstyle
                                                              May 15 at 1:15















                                                            1












                                                            $begingroup$


                                                            Python 3, 110 108 102 bytes



                                                            Similar method to my Mathematica answer (i.e. isPrime(1+⌊¾n²⌋) else n++)
                                                            using this golfed prime checker and returning an anonymous infinite generator





                                                            from itertools import*
                                                            (x for x in map(lambda n:1+3*n**2//4,count(2)) if all(x%j for j in range(2,x)))


                                                            Try it online!




                                                            • mypetlion -2 because arguably anonymous generators are more allowed than named ones


                                                            • -6 by starting count at 2 +1 so that the and x>1 in the prime checker I borrowed is unnecessary -7





                                                            share|improve this answer











                                                            $endgroup$












                                                            • $begingroup$
                                                              The answer going into a variable is usually not considered a valid form of "output". Could you rework your answer so that the result is either output to stdout or returned by a function?
                                                              $endgroup$
                                                              – mypetlion
                                                              May 14 at 23:01






                                                            • 1




                                                              $begingroup$
                                                              since anonymous functions are allowed, and the challenge explicitly allows an infinite generator, I've removed g=. I had only included it in the first place because it allowed a quick visual on TIO with print(next(g) for i in range(52)).
                                                              $endgroup$
                                                              – speedstyle
                                                              May 15 at 1:15













                                                            1












                                                            1








                                                            1





                                                            $begingroup$


                                                            Python 3, 110 108 102 bytes



                                                            Similar method to my Mathematica answer (i.e. isPrime(1+⌊¾n²⌋) else n++)
                                                            using this golfed prime checker and returning an anonymous infinite generator





                                                            from itertools import*
                                                            (x for x in map(lambda n:1+3*n**2//4,count(2)) if all(x%j for j in range(2,x)))


                                                            Try it online!




                                                            • mypetlion -2 because arguably anonymous generators are more allowed than named ones


                                                            • -6 by starting count at 2 +1 so that the and x>1 in the prime checker I borrowed is unnecessary -7





                                                            share|improve this answer











                                                            $endgroup$




                                                            Python 3, 110 108 102 bytes



                                                            Similar method to my Mathematica answer (i.e. isPrime(1+⌊¾n²⌋) else n++)
                                                            using this golfed prime checker and returning an anonymous infinite generator





                                                            from itertools import*
                                                            (x for x in map(lambda n:1+3*n**2//4,count(2)) if all(x%j for j in range(2,x)))


                                                            Try it online!




                                                            • mypetlion -2 because arguably anonymous generators are more allowed than named ones


                                                            • -6 by starting count at 2 +1 so that the and x>1 in the prime checker I borrowed is unnecessary -7






                                                            share|improve this answer














                                                            share|improve this answer



                                                            share|improve this answer








                                                            edited May 15 at 9:28

























                                                            answered May 14 at 20:44









                                                            speedstylespeedstyle

                                                            695




                                                            695











                                                            • $begingroup$
                                                              The answer going into a variable is usually not considered a valid form of "output". Could you rework your answer so that the result is either output to stdout or returned by a function?
                                                              $endgroup$
                                                              – mypetlion
                                                              May 14 at 23:01






                                                            • 1




                                                              $begingroup$
                                                              since anonymous functions are allowed, and the challenge explicitly allows an infinite generator, I've removed g=. I had only included it in the first place because it allowed a quick visual on TIO with print(next(g) for i in range(52)).
                                                              $endgroup$
                                                              – speedstyle
                                                              May 15 at 1:15
















                                                            • $begingroup$
                                                              The answer going into a variable is usually not considered a valid form of "output". Could you rework your answer so that the result is either output to stdout or returned by a function?
                                                              $endgroup$
                                                              – mypetlion
                                                              May 14 at 23:01






                                                            • 1




                                                              $begingroup$
                                                              since anonymous functions are allowed, and the challenge explicitly allows an infinite generator, I've removed g=. I had only included it in the first place because it allowed a quick visual on TIO with print(next(g) for i in range(52)).
                                                              $endgroup$
                                                              – speedstyle
                                                              May 15 at 1:15















                                                            $begingroup$
                                                            The answer going into a variable is usually not considered a valid form of "output". Could you rework your answer so that the result is either output to stdout or returned by a function?
                                                            $endgroup$
                                                            – mypetlion
                                                            May 14 at 23:01




                                                            $begingroup$
                                                            The answer going into a variable is usually not considered a valid form of "output". Could you rework your answer so that the result is either output to stdout or returned by a function?
                                                            $endgroup$
                                                            – mypetlion
                                                            May 14 at 23:01




                                                            1




                                                            1




                                                            $begingroup$
                                                            since anonymous functions are allowed, and the challenge explicitly allows an infinite generator, I've removed g=. I had only included it in the first place because it allowed a quick visual on TIO with print(next(g) for i in range(52)).
                                                            $endgroup$
                                                            – speedstyle
                                                            May 15 at 1:15




                                                            $begingroup$
                                                            since anonymous functions are allowed, and the challenge explicitly allows an infinite generator, I've removed g=. I had only included it in the first place because it allowed a quick visual on TIO with print(next(g) for i in range(52)).
                                                            $endgroup$
                                                            – speedstyle
                                                            May 15 at 1:15











                                                            1












                                                            $begingroup$


                                                            Japt, 14 13 bytes



                                                            Adapted from Arnauld's formula. 1-indexed.



                                                            @µXj}f@Ò(X²*¾


                                                            Try it



                                                            1 byte saved thanks to EmbodimentOfIgnorance.






                                                            share|improve this answer











                                                            $endgroup$












                                                            • $begingroup$
                                                              13 bytes? Not tested thoroughly though.
                                                              $endgroup$
                                                              – Embodiment of Ignorance
                                                              May 15 at 2:15










                                                            • $begingroup$
                                                              Thanks, @EmbodimentofIgnorance. I'd tried that but it didn't work; turns out I'd forgotten the (.
                                                              $endgroup$
                                                              – Shaggy
                                                              May 15 at 9:47















                                                            1












                                                            $begingroup$


                                                            Japt, 14 13 bytes



                                                            Adapted from Arnauld's formula. 1-indexed.



                                                            @µXj}f@Ò(X²*¾


                                                            Try it



                                                            1 byte saved thanks to EmbodimentOfIgnorance.






                                                            share|improve this answer











                                                            $endgroup$












                                                            • $begingroup$
                                                              13 bytes? Not tested thoroughly though.
                                                              $endgroup$
                                                              – Embodiment of Ignorance
                                                              May 15 at 2:15










                                                            • $begingroup$
                                                              Thanks, @EmbodimentofIgnorance. I'd tried that but it didn't work; turns out I'd forgotten the (.
                                                              $endgroup$
                                                              – Shaggy
                                                              May 15 at 9:47













                                                            1












                                                            1








                                                            1





                                                            $begingroup$


                                                            Japt, 14 13 bytes



                                                            Adapted from Arnauld's formula. 1-indexed.



                                                            @µXj}f@Ò(X²*¾


                                                            Try it



                                                            1 byte saved thanks to EmbodimentOfIgnorance.






                                                            share|improve this answer











                                                            $endgroup$




                                                            Japt, 14 13 bytes



                                                            Adapted from Arnauld's formula. 1-indexed.



                                                            @µXj}f@Ò(X²*¾


                                                            Try it



                                                            1 byte saved thanks to EmbodimentOfIgnorance.







                                                            share|improve this answer














                                                            share|improve this answer



                                                            share|improve this answer








                                                            edited May 15 at 9:46

























                                                            answered May 14 at 21:25









                                                            ShaggyShaggy

                                                            19.5k31768




                                                            19.5k31768











                                                            • $begingroup$
                                                              13 bytes? Not tested thoroughly though.
                                                              $endgroup$
                                                              – Embodiment of Ignorance
                                                              May 15 at 2:15










                                                            • $begingroup$
                                                              Thanks, @EmbodimentofIgnorance. I'd tried that but it didn't work; turns out I'd forgotten the (.
                                                              $endgroup$
                                                              – Shaggy
                                                              May 15 at 9:47
















                                                            • $begingroup$
                                                              13 bytes? Not tested thoroughly though.
                                                              $endgroup$
                                                              – Embodiment of Ignorance
                                                              May 15 at 2:15










                                                            • $begingroup$
                                                              Thanks, @EmbodimentofIgnorance. I'd tried that but it didn't work; turns out I'd forgotten the (.
                                                              $endgroup$
                                                              – Shaggy
                                                              May 15 at 9:47















                                                            $begingroup$
                                                            13 bytes? Not tested thoroughly though.
                                                            $endgroup$
                                                            – Embodiment of Ignorance
                                                            May 15 at 2:15




                                                            $begingroup$
                                                            13 bytes? Not tested thoroughly though.
                                                            $endgroup$
                                                            – Embodiment of Ignorance
                                                            May 15 at 2:15












                                                            $begingroup$
                                                            Thanks, @EmbodimentofIgnorance. I'd tried that but it didn't work; turns out I'd forgotten the (.
                                                            $endgroup$
                                                            – Shaggy
                                                            May 15 at 9:47




                                                            $begingroup$
                                                            Thanks, @EmbodimentofIgnorance. I'd tried that but it didn't work; turns out I'd forgotten the (.
                                                            $endgroup$
                                                            – Shaggy
                                                            May 15 at 9:47











                                                            1












                                                            $begingroup$


                                                            Racket, 124 bytes



                                                            (require math)(define(f n[i 3])(let([t(+(exact-floor(* 3/4 i i))1)][k(+ 1 i)])(if(prime? t)(if(= 0 n)t(f(- n 1)k))(f n k))))


                                                            Try it online!



                                                            Returns the n-th cuban prime, 0-indexed.



                                                            Uses the formula of @Arnauld's JavaScript answer






                                                            share|improve this answer











                                                            $endgroup$

















                                                              1












                                                              $begingroup$


                                                              Racket, 124 bytes



                                                              (require math)(define(f n[i 3])(let([t(+(exact-floor(* 3/4 i i))1)][k(+ 1 i)])(if(prime? t)(if(= 0 n)t(f(- n 1)k))(f n k))))


                                                              Try it online!



                                                              Returns the n-th cuban prime, 0-indexed.



                                                              Uses the formula of @Arnauld's JavaScript answer






                                                              share|improve this answer











                                                              $endgroup$















                                                                1












                                                                1








                                                                1





                                                                $begingroup$


                                                                Racket, 124 bytes



                                                                (require math)(define(f n[i 3])(let([t(+(exact-floor(* 3/4 i i))1)][k(+ 1 i)])(if(prime? t)(if(= 0 n)t(f(- n 1)k))(f n k))))


                                                                Try it online!



                                                                Returns the n-th cuban prime, 0-indexed.



                                                                Uses the formula of @Arnauld's JavaScript answer






                                                                share|improve this answer











                                                                $endgroup$




                                                                Racket, 124 bytes



                                                                (require math)(define(f n[i 3])(let([t(+(exact-floor(* 3/4 i i))1)][k(+ 1 i)])(if(prime? t)(if(= 0 n)t(f(- n 1)k))(f n k))))


                                                                Try it online!



                                                                Returns the n-th cuban prime, 0-indexed.



                                                                Uses the formula of @Arnauld's JavaScript answer







                                                                share|improve this answer














                                                                share|improve this answer



                                                                share|improve this answer








                                                                edited May 15 at 10:13

























                                                                answered May 15 at 7:46









                                                                Galen IvanovGalen Ivanov

                                                                8,25711137




                                                                8,25711137





















                                                                    1












                                                                    $begingroup$


                                                                    Python 3, 83 bytes



                                                                    prints the cuban primes forever.





                                                                    P=k=1
                                                                    while 1:P*=k*k;x=k;k+=1;P%k>0==((x/3)**.5%1)*((x/3+.25)**.5%1-.5)and print(k)


                                                                    Try it online!



                                                                    Based on this prime generator. For every prime it checks whether an integer y exists that fulfills the equation for either $x = 1+y$ or $x=2+y$.



                                                                    $$ p=frac(1+y)^3-y^3(1+y)-y = 1 + 3y +3y^2 Leftrightarrow y = -frac12pmsqrtfrac14+fracp-13$$



                                                                    $$ p=frac(2+y)^3-y^3(1+y)-y = 4 + 6y +3y^2 Leftrightarrow y = -1 pmsqrtfracp-13$$
                                                                    As we only care whether $y$ has an integer solution, we can ignore the $pm$ and $-1$.






                                                                    share|improve this answer











                                                                    $endgroup$

















                                                                      1












                                                                      $begingroup$


                                                                      Python 3, 83 bytes



                                                                      prints the cuban primes forever.





                                                                      P=k=1
                                                                      while 1:P*=k*k;x=k;k+=1;P%k>0==((x/3)**.5%1)*((x/3+.25)**.5%1-.5)and print(k)


                                                                      Try it online!



                                                                      Based on this prime generator. For every prime it checks whether an integer y exists that fulfills the equation for either $x = 1+y$ or $x=2+y$.



                                                                      $$ p=frac(1+y)^3-y^3(1+y)-y = 1 + 3y +3y^2 Leftrightarrow y = -frac12pmsqrtfrac14+fracp-13$$



                                                                      $$ p=frac(2+y)^3-y^3(1+y)-y = 4 + 6y +3y^2 Leftrightarrow y = -1 pmsqrtfracp-13$$
                                                                      As we only care whether $y$ has an integer solution, we can ignore the $pm$ and $-1$.






                                                                      share|improve this answer











                                                                      $endgroup$















                                                                        1












                                                                        1








                                                                        1





                                                                        $begingroup$


                                                                        Python 3, 83 bytes



                                                                        prints the cuban primes forever.





                                                                        P=k=1
                                                                        while 1:P*=k*k;x=k;k+=1;P%k>0==((x/3)**.5%1)*((x/3+.25)**.5%1-.5)and print(k)


                                                                        Try it online!



                                                                        Based on this prime generator. For every prime it checks whether an integer y exists that fulfills the equation for either $x = 1+y$ or $x=2+y$.



                                                                        $$ p=frac(1+y)^3-y^3(1+y)-y = 1 + 3y +3y^2 Leftrightarrow y = -frac12pmsqrtfrac14+fracp-13$$



                                                                        $$ p=frac(2+y)^3-y^3(1+y)-y = 4 + 6y +3y^2 Leftrightarrow y = -1 pmsqrtfracp-13$$
                                                                        As we only care whether $y$ has an integer solution, we can ignore the $pm$ and $-1$.






                                                                        share|improve this answer











                                                                        $endgroup$




                                                                        Python 3, 83 bytes



                                                                        prints the cuban primes forever.





                                                                        P=k=1
                                                                        while 1:P*=k*k;x=k;k+=1;P%k>0==((x/3)**.5%1)*((x/3+.25)**.5%1-.5)and print(k)


                                                                        Try it online!



                                                                        Based on this prime generator. For every prime it checks whether an integer y exists that fulfills the equation for either $x = 1+y$ or $x=2+y$.



                                                                        $$ p=frac(1+y)^3-y^3(1+y)-y = 1 + 3y +3y^2 Leftrightarrow y = -frac12pmsqrtfrac14+fracp-13$$



                                                                        $$ p=frac(2+y)^3-y^3(1+y)-y = 4 + 6y +3y^2 Leftrightarrow y = -1 pmsqrtfracp-13$$
                                                                        As we only care whether $y$ has an integer solution, we can ignore the $pm$ and $-1$.







                                                                        share|improve this answer














                                                                        share|improve this answer



                                                                        share|improve this answer








                                                                        edited May 15 at 14:46

























                                                                        answered May 15 at 14:32









                                                                        ovsovs

                                                                        19.7k21161




                                                                        19.7k21161





















                                                                            1












                                                                            $begingroup$


                                                                            Perl 6, 33 31 bytes



                                                                            -2 bytes thanks to Grimy





                                                                            ¾*$++²xx*


                                                                            Try it online!



                                                                            Anonymous code block that returns a lazy infinite list of Cuban primes. This uses Arnauld's formula to generate possible cuban primes, then &is-prime to filter them.



                                                                            Explanation:



                                                                             # Anonymous code block
                                                                            grep &is-prime, # Filter the primes from
                                                                            xx* # The infinite list
                                                                            ¾* # Of three quarters
                                                                            $++² # Of an increasing number squared
                                                                            1+| # Add one by ORing with 1





                                                                            share|improve this answer











                                                                            $endgroup$








                                                                            • 1




                                                                              $begingroup$
                                                                              1+0+| can be just 1+|
                                                                              $endgroup$
                                                                              – Grimy
                                                                              May 16 at 10:49















                                                                            1












                                                                            $begingroup$


                                                                            Perl 6, 33 31 bytes



                                                                            -2 bytes thanks to Grimy





                                                                            ¾*$++²xx*


                                                                            Try it online!



                                                                            Anonymous code block that returns a lazy infinite list of Cuban primes. This uses Arnauld's formula to generate possible cuban primes, then &is-prime to filter them.



                                                                            Explanation:



                                                                             # Anonymous code block
                                                                            grep &is-prime, # Filter the primes from
                                                                            xx* # The infinite list
                                                                            ¾* # Of three quarters
                                                                            $++² # Of an increasing number squared
                                                                            1+| # Add one by ORing with 1





                                                                            share|improve this answer











                                                                            $endgroup$








                                                                            • 1




                                                                              $begingroup$
                                                                              1+0+| can be just 1+|
                                                                              $endgroup$
                                                                              – Grimy
                                                                              May 16 at 10:49













                                                                            1












                                                                            1








                                                                            1





                                                                            $begingroup$


                                                                            Perl 6, 33 31 bytes



                                                                            -2 bytes thanks to Grimy





                                                                            ¾*$++²xx*


                                                                            Try it online!



                                                                            Anonymous code block that returns a lazy infinite list of Cuban primes. This uses Arnauld's formula to generate possible cuban primes, then &is-prime to filter them.



                                                                            Explanation:



                                                                             # Anonymous code block
                                                                            grep &is-prime, # Filter the primes from
                                                                            xx* # The infinite list
                                                                            ¾* # Of three quarters
                                                                            $++² # Of an increasing number squared
                                                                            1+| # Add one by ORing with 1





                                                                            share|improve this answer











                                                                            $endgroup$




                                                                            Perl 6, 33 31 bytes



                                                                            -2 bytes thanks to Grimy





                                                                            ¾*$++²xx*


                                                                            Try it online!



                                                                            Anonymous code block that returns a lazy infinite list of Cuban primes. This uses Arnauld's formula to generate possible cuban primes, then &is-prime to filter them.



                                                                            Explanation:



                                                                             # Anonymous code block
                                                                            grep &is-prime, # Filter the primes from
                                                                            xx* # The infinite list
                                                                            ¾* # Of three quarters
                                                                            $++² # Of an increasing number squared
                                                                            1+| # Add one by ORing with 1






                                                                            share|improve this answer














                                                                            share|improve this answer



                                                                            share|improve this answer








                                                                            edited May 16 at 11:14

























                                                                            answered May 16 at 5:05









                                                                            Jo KingJo King

                                                                            28.4k366134




                                                                            28.4k366134







                                                                            • 1




                                                                              $begingroup$
                                                                              1+0+| can be just 1+|
                                                                              $endgroup$
                                                                              – Grimy
                                                                              May 16 at 10:49












                                                                            • 1




                                                                              $begingroup$
                                                                              1+0+| can be just 1+|
                                                                              $endgroup$
                                                                              – Grimy
                                                                              May 16 at 10:49







                                                                            1




                                                                            1




                                                                            $begingroup$
                                                                            1+0+| can be just 1+|
                                                                            $endgroup$
                                                                            – Grimy
                                                                            May 16 at 10:49




                                                                            $begingroup$
                                                                            1+0+| can be just 1+|
                                                                            $endgroup$
                                                                            – Grimy
                                                                            May 16 at 10:49











                                                                            0












                                                                            $begingroup$


                                                                            Pari/GP, 51 bytes



                                                                            Using Arnauld's formula.



                                                                            n->a=0;for(i=1,n,until(isprime(p=3*a^24+1),a++));p


                                                                            Try it online!






                                                                            share|improve this answer









                                                                            $endgroup$

















                                                                              0












                                                                              $begingroup$


                                                                              Pari/GP, 51 bytes



                                                                              Using Arnauld's formula.



                                                                              n->a=0;for(i=1,n,until(isprime(p=3*a^24+1),a++));p


                                                                              Try it online!






                                                                              share|improve this answer









                                                                              $endgroup$















                                                                                0












                                                                                0








                                                                                0





                                                                                $begingroup$


                                                                                Pari/GP, 51 bytes



                                                                                Using Arnauld's formula.



                                                                                n->a=0;for(i=1,n,until(isprime(p=3*a^24+1),a++));p


                                                                                Try it online!






                                                                                share|improve this answer









                                                                                $endgroup$




                                                                                Pari/GP, 51 bytes



                                                                                Using Arnauld's formula.



                                                                                n->a=0;for(i=1,n,until(isprime(p=3*a^24+1),a++));p


                                                                                Try it online!







                                                                                share|improve this answer












                                                                                share|improve this answer



                                                                                share|improve this answer










                                                                                answered May 16 at 4:46









                                                                                alephalphaalephalpha

                                                                                22.4k33096




                                                                                22.4k33096





















                                                                                    0












                                                                                    $begingroup$

                                                                                    APL(NARS), 98 chars, 196 bytes



                                                                                    r←h w;y;c;v
                                                                                    r←c←y←0⋄→4
                                                                                    →3×⍳∼0πv←1+3×y×1+y+←1⋄r←v⋄→0×⍳w≤c+←1
                                                                                    →2×⍳∼0πv+←3×y+1⋄c+←1⋄r←v
                                                                                    →2×⍳w>c


                                                                                    indented :



                                                                                    r←h w;y;c;v
                                                                                    r←c←y←0⋄→4
                                                                                    →3×⍳∼0πv←1+3×y×1+y+←1⋄r←v⋄→0×⍳w≤c+←1
                                                                                    →2×⍳∼0πv+←3×y+1⋄c+←1⋄r←v
                                                                                    →2×⍳w>c


                                                                                    test:



                                                                                     h ¨1..20
                                                                                    7 13 19 37 61 109 127 193 271 331 397 433 547 631 769 919 1201 1453 1657 1801
                                                                                    h 1000
                                                                                    25789873
                                                                                    h 10000
                                                                                    4765143511


                                                                                    it is based on: if y in N, one possible Cuban Prime is



                                                                                    S1=1+3y(y+1)


                                                                                    the the next possible Cuban Prime will be



                                                                                    S2=3(y+1)+S1





                                                                                    share|improve this answer











                                                                                    $endgroup$

















                                                                                      0












                                                                                      $begingroup$

                                                                                      APL(NARS), 98 chars, 196 bytes



                                                                                      r←h w;y;c;v
                                                                                      r←c←y←0⋄→4
                                                                                      →3×⍳∼0πv←1+3×y×1+y+←1⋄r←v⋄→0×⍳w≤c+←1
                                                                                      →2×⍳∼0πv+←3×y+1⋄c+←1⋄r←v
                                                                                      →2×⍳w>c


                                                                                      indented :



                                                                                      r←h w;y;c;v
                                                                                      r←c←y←0⋄→4
                                                                                      →3×⍳∼0πv←1+3×y×1+y+←1⋄r←v⋄→0×⍳w≤c+←1
                                                                                      →2×⍳∼0πv+←3×y+1⋄c+←1⋄r←v
                                                                                      →2×⍳w>c


                                                                                      test:



                                                                                       h ¨1..20
                                                                                      7 13 19 37 61 109 127 193 271 331 397 433 547 631 769 919 1201 1453 1657 1801
                                                                                      h 1000
                                                                                      25789873
                                                                                      h 10000
                                                                                      4765143511


                                                                                      it is based on: if y in N, one possible Cuban Prime is



                                                                                      S1=1+3y(y+1)


                                                                                      the the next possible Cuban Prime will be



                                                                                      S2=3(y+1)+S1





                                                                                      share|improve this answer











                                                                                      $endgroup$















                                                                                        0












                                                                                        0








                                                                                        0





                                                                                        $begingroup$

                                                                                        APL(NARS), 98 chars, 196 bytes



                                                                                        r←h w;y;c;v
                                                                                        r←c←y←0⋄→4
                                                                                        →3×⍳∼0πv←1+3×y×1+y+←1⋄r←v⋄→0×⍳w≤c+←1
                                                                                        →2×⍳∼0πv+←3×y+1⋄c+←1⋄r←v
                                                                                        →2×⍳w>c


                                                                                        indented :



                                                                                        r←h w;y;c;v
                                                                                        r←c←y←0⋄→4
                                                                                        →3×⍳∼0πv←1+3×y×1+y+←1⋄r←v⋄→0×⍳w≤c+←1
                                                                                        →2×⍳∼0πv+←3×y+1⋄c+←1⋄r←v
                                                                                        →2×⍳w>c


                                                                                        test:



                                                                                         h ¨1..20
                                                                                        7 13 19 37 61 109 127 193 271 331 397 433 547 631 769 919 1201 1453 1657 1801
                                                                                        h 1000
                                                                                        25789873
                                                                                        h 10000
                                                                                        4765143511


                                                                                        it is based on: if y in N, one possible Cuban Prime is



                                                                                        S1=1+3y(y+1)


                                                                                        the the next possible Cuban Prime will be



                                                                                        S2=3(y+1)+S1





                                                                                        share|improve this answer











                                                                                        $endgroup$



                                                                                        APL(NARS), 98 chars, 196 bytes



                                                                                        r←h w;y;c;v
                                                                                        r←c←y←0⋄→4
                                                                                        →3×⍳∼0πv←1+3×y×1+y+←1⋄r←v⋄→0×⍳w≤c+←1
                                                                                        →2×⍳∼0πv+←3×y+1⋄c+←1⋄r←v
                                                                                        →2×⍳w>c


                                                                                        indented :



                                                                                        r←h w;y;c;v
                                                                                        r←c←y←0⋄→4
                                                                                        →3×⍳∼0πv←1+3×y×1+y+←1⋄r←v⋄→0×⍳w≤c+←1
                                                                                        →2×⍳∼0πv+←3×y+1⋄c+←1⋄r←v
                                                                                        →2×⍳w>c


                                                                                        test:



                                                                                         h ¨1..20
                                                                                        7 13 19 37 61 109 127 193 271 331 397 433 547 631 769 919 1201 1453 1657 1801
                                                                                        h 1000
                                                                                        25789873
                                                                                        h 10000
                                                                                        4765143511


                                                                                        it is based on: if y in N, one possible Cuban Prime is



                                                                                        S1=1+3y(y+1)


                                                                                        the the next possible Cuban Prime will be



                                                                                        S2=3(y+1)+S1






                                                                                        share|improve this answer














                                                                                        share|improve this answer



                                                                                        share|improve this answer








                                                                                        edited May 23 at 10:04

























                                                                                        answered May 16 at 8:33









                                                                                        RosLuPRosLuP

                                                                                        2,346514




                                                                                        2,346514



























                                                                                            draft saved

                                                                                            draft discarded
















































                                                                                            If this is an answer to a challenge…



                                                                                            • …Be sure to follow the challenge specification. However, please refrain from exploiting obvious loopholes. Answers abusing any of the standard loopholes are considered invalid. If you think a specification is unclear or underspecified, comment on the question instead.


                                                                                            • …Try to optimize your score. For instance, answers to code-golf challenges should attempt to be as short as possible. You can always include a readable version of the code in addition to the competitive one.
                                                                                              Explanations of your answer make it more interesting to read and are very much encouraged.


                                                                                            • …Include a short header which indicates the language(s) of your code and its score, as defined by the challenge.


                                                                                            More generally…



                                                                                            • …Please make sure to answer the question and provide sufficient detail.


                                                                                            • …Avoid asking for help, clarification or responding to other answers (use comments instead).




                                                                                            draft saved


                                                                                            draft discarded














                                                                                            StackExchange.ready(
                                                                                            function ()
                                                                                            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodegolf.stackexchange.com%2fquestions%2f185567%2fcuban-primes%23new-answer', 'question_page');

                                                                                            );

                                                                                            Post as a guest















                                                                                            Required, but never shown





















































                                                                                            Required, but never shown














                                                                                            Required, but never shown












                                                                                            Required, but never shown







                                                                                            Required, but never shown

































                                                                                            Required, but never shown














                                                                                            Required, but never shown












                                                                                            Required, but never shown







                                                                                            Required, but never shown







                                                                                            Popular posts from this blog

                                                                                            Club Baloncesto Breogán Índice Historia | Pavillón | Nome | O Breogán na cultura popular | Xogadores | Adestradores | Presidentes | Palmarés | Historial | Líderes | Notas | Véxase tamén | Menú de navegacióncbbreogan.galCadroGuía oficial da ACB 2009-10, páxina 201Guía oficial ACB 1992, páxina 183. Editorial DB.É de 6.500 espectadores sentados axeitándose á última normativa"Estudiantes Junior, entre as mellores canteiras"o orixinalHemeroteca El Mundo Deportivo, 16 setembro de 1970, páxina 12Historia do BreogánAlfredo Pérez, o último canoneiroHistoria C.B. BreogánHemeroteca de El Mundo DeportivoJimmy Wright, norteamericano do Breogán deixará Lugo por ameazas de morteResultados de Breogán en 1986-87Resultados de Breogán en 1990-91Ficha de Velimir Perasović en acb.comResultados de Breogán en 1994-95Breogán arrasa al Barça. "El Mundo Deportivo", 27 de setembro de 1999, páxina 58CB Breogán - FC BarcelonaA FEB invita a participar nunha nova Liga EuropeaCharlie Bell na prensa estatalMáximos anotadores 2005Tempada 2005-06 : Tódolos Xogadores da Xornada""Non quero pensar nunha man negra, mais pregúntome que está a pasar""o orixinalRaúl López, orgulloso dos xogadores, presume da boa saúde económica do BreogánJulio González confirma que cesa como presidente del BreogánHomenaxe a Lisardo GómezA tempada do rexurdimento celesteEntrevista a Lisardo GómezEl COB dinamita el Pazo para forzar el quinto (69-73)Cafés Candelas, patrocinador del CB Breogán"Suso Lázare, novo presidente do Breogán"o orixinalCafés Candelas Breogán firma el mayor triunfo de la historiaEl Breogán realizará 17 homenajes por su cincuenta aniversario"O Breogán honra ao seu fundador e primeiro presidente"o orixinalMiguel Giao recibiu a homenaxe do PazoHomenaxe aos primeiros gladiadores celestesO home que nos amosa como ver o Breo co corazónTita Franco será homenaxeada polos #50anosdeBreoJulio Vila recibirá unha homenaxe in memoriam polos #50anosdeBreo"O Breogán homenaxeará aos seus aboados máis veteráns"Pechada ovación a «Capi» Sanmartín e Ricardo «Corazón de González»Homenaxe por décadas de informaciónPaco García volve ao Pazo con motivo do 50 aniversario"Resultados y clasificaciones""O Cafés Candelas Breogán, campión da Copa Princesa""O Cafés Candelas Breogán, equipo ACB"C.B. Breogán"Proxecto social"o orixinal"Centros asociados"o orixinalFicha en imdb.comMario Camus trata la recuperación del amor en 'La vieja música', su última película"Páxina web oficial""Club Baloncesto Breogán""C. B. Breogán S.A.D."eehttp://www.fegaba.com

                                                                                            Vilaño, A Laracha Índice Patrimonio | Lugares e parroquias | Véxase tamén | Menú de navegación43°14′52″N 8°36′03″O / 43.24775, -8.60070

                                                                                            Cegueira Índice Epidemioloxía | Deficiencia visual | Tipos de cegueira | Principais causas de cegueira | Tratamento | Técnicas de adaptación e axudas | Vida dos cegos | Primeiros auxilios | Crenzas respecto das persoas cegas | Crenzas das persoas cegas | O neno deficiente visual | Aspectos psicolóxicos da cegueira | Notas | Véxase tamén | Menú de navegación54.054.154.436928256blindnessDicionario da Real Academia GalegaPortal das Palabras"International Standards: Visual Standards — Aspects and Ranges of Vision Loss with Emphasis on Population Surveys.""Visual impairment and blindness""Presentan un plan para previr a cegueira"o orixinalACCDV Associació Catalana de Cecs i Disminuïts Visuals - PMFTrachoma"Effect of gene therapy on visual function in Leber's congenital amaurosis"1844137110.1056/NEJMoa0802268Cans guía - os mellores amigos dos cegosArquivadoEscola de cans guía para cegos en Mortágua, PortugalArquivado"Tecnología para ciegos y deficientes visuales. Recopilación de recursos gratuitos en la Red""Colorino""‘COL.diesis’, escuchar los sonidos del color""COL.diesis: Transforming Colour into Melody and Implementing the Result in a Colour Sensor Device"o orixinal"Sistema de desarrollo de sinestesia color-sonido para invidentes utilizando un protocolo de audio""Enseñanza táctil - geometría y color. Juegos didácticos para niños ciegos y videntes""Sistema Constanz"L'ocupació laboral dels cecs a l'Estat espanyol està pràcticament equiparada a la de les persones amb visió, entrevista amb Pedro ZuritaONCE (Organización Nacional de Cegos de España)Prevención da cegueiraDescrición de deficiencias visuais (Disc@pnet)Braillín, un boneco atractivo para calquera neno, con ou sen discapacidade, que permite familiarizarse co sistema de escritura e lectura brailleAxudas Técnicas36838ID00897494007150-90057129528256DOID:1432HP:0000618D001766C10.597.751.941.162C97109C0155020