Zabierz mnie za siebie, szatanie!


22

Szatani-Pierwsi

kim oni są?
Primeszawierające 666
to Szatan-Najwyżsi: [46663,266677,666599,666683,616669]
to NIE :[462667,665669,36363631,555]

Wątek

Każda liczba większa niż 6661 ma za sobą Szatana-Najwyższych

Wyzwanie

Podano liczbę całkowitą n>6661 znajdź Najwyższego Szatana za (lub równym) i najbliżej siebie.

Przykłady

Integer n=30000ma 3 szatan liczb pierwszych (SP) za nim: [6661, 16661, 26669].
Twój kod musi zostać zwrócony26669 co jest najbliżej niego

Przypadki testowe

Wejście-> Wyjście

6662->6661    
10000->6661    
66697->66697 (a SP returns himself)  
328765->326663  
678987->676661
969696->966677

Zasady

Twój kod powinien działać dla każdego nTwój w Twoim języku.

To jest , więc wygrywa najkrótsza odpowiedź w bajtach!


1
zdefiniuj „około minuty”. Czy to + - 30 sekund? Osobiście uważam, że 30 minut i minut nie różnią się aż tak bardzo ... Poza tym bonusy są generalnie odrzucane ... myślę też, że może to być lepsze output the nth satan primewyzwanie ...
Socratic Phoenix

ok ok ludzie ... bonus zostanie usunięty ...

Mam nadzieję, że nie masz nic przeciwko edycji, której dokonałem w tytule wyzwania.
Kudłaty

3
@Shaggy Do czego służy zmiana tytułu ...?
Conor O'Brien

3
@ ConorO'Brien Rymowanie i wydaje się archaiczne, jak sądzę.
wizzwizz4

Odpowiedzi:



7

Neim , 9 bajtów

>ͻ:D+6S𝕚÷

Wyjaśnienie:

>         Increment input
 ͻ        Start infinite loop
  :        Previous prime
   D       Duplicate
    +6     Push 666
      S    Swap
       𝕚   See if 666 is a substring of the top of the stack
        ÷  If true, break

Wypróbuj online!


Czy naprawdę jest wbudowana funkcja wypychania „66 przed cyfrą”? O_O Neim zrobił postępy.
Erik the Outgolfer,

1
Jak działa +6Push 666? A może Neim to tylko metal?
Robert Fraser

6
@RobertFraser Najwyraźniej +xoznacza 612 + kod znaków x. Kodem 6jest 54, więc 612 + 54 = 666.
fergusq

@EriktheOutgolfer Cóż, Neim może reprezentować wszystkie trzy cyfry i kilka czterech cyfr za pomocą dwóch bajtów.
Okx,

2
@EriktheOutgolfer '\+*=100,356,612,868 (plus porządek następnego znaku, który jest)
Jonathan Allan

7

Galaretka , 10 9 bajtów

Zaoszczędź 10% dzięki @Dennis!

ÆRwÐf666Ṫ

Wypróbuj online!

Wyjaśnienie

ÆR          # All primes in range [2, input]
   Ðf      # Keep those which satisfy
  w        # truthy if y is in x
     666   #           ^ (this is y)
        Ṫ  # Tail (take the last element)

Alternatywnie:ÆRẇ@Ðf666Ṁ
Pan Xcoder,

5
Uwielbiam to, że Ogon (zaraz po 666) wygląda jak krzyż.
kaine

4
wpowinien działać zamiast ẇ@.
Dennis

@Dennis s / sh / w / oczywiście działa: p
Erik the Outgolfer

5

Pyt , 15 14 bajtów

Zapisano 1 bajt z pomocą Dave'a .

Błędy pamięci dla 969696 i cokolwiek wyższego na moim komputerze, ale dobrze jest, jeśli ma wystarczającą ilość pamięci.

ef&/`T*3\6P_TS

Wypróbuj tutaj lub sprawdź pakiet testowy.


W jaki sposób?

ef & / `T * 3 \ 6P_TSQ - Pełny program, z niejawnym wejściem (Q) na końcu

             SQ - Zakres [1, Q]
 f - Filtruj.
          P_T - Czy liczba pierwsza?
  & - I
   / `T * 3 \ 6 - Zawiera 666.
e - ostatni element.
                - Wyjmij wynik niejawnie.

Pyth , 14 bajtów

ef/`T*\63fP_TS

Wypróbuj tutaj!


14 bajtów:ef&/`T*3\6P_TS
Dave

Końcowe Q dodałem przez pomyłkę, jego 14
Dave

"666"jest mniej skutecznym sposobem na opisanie ciągu 666, który*3\6
Dave


4

Bash + Core Utils, 51 49 bajtów

seq $1|tac|factor|awk 'NF==2&&/666/&&!a--&&$0=$2'

Bierze argument z wiersza poleceń. Może być dość wolny przy większych liczbach.


Spowoduje to wyświetlenie wszystkich „liczb pierwszych szatana” do 6661, ale powinien wypisać tylko najbliższą wartość poniżej wejścia: wypróbuj online . Jedną poprawką byłoby po prostu dodać |head -1do końca.
Justin Mariner

@JustinMariner lol, ups, naprawił to
markasoftware

4

Mathematica, 64 62 61 53 bajtów

#//.i_/;!PrimeQ@i||ToString@i~StringFreeQ~"666":>i-1&

-1 bajt dzięki @KellyLowder

-8 bajtów (wow) dzięki @Notatree

Wyjaśnienie

Weź udział. Zmniejszamy to na następujących warunkach:

  • wejście nie jest liczbą pierwszą LUB

  • cyfry danych wejściowych nie zawierają trzech 6s z rzędu.

Powtarzamy to aż do osiągnięcia szatana.


2
Bardzo dobrze. Możesz stracić jeszcze jedno _ na końcu, ponieważ liczba pierwsza nie może kończyć się na 6.
Kelly Lowder

@ KellyLowder dobry punkt
JungHwan Min

1
Jest to jeszcze krótsze w przypadku łańcuchów:#//.i_/;!PrimeQ@i||ToString@i~StringFreeQ~"666":>i-1&
Bez drzewa

1
@Notatree wow! miły!
JungHwan Min


3

Japt , 14 bajtów

õ fj w æ_sø666

Sprawdź to

Skoro nie było Bonus 50% czasu na bazie: sprawdzian finalizuje 969696się pod pół sekundy.


Wyjaśnienie

Domniemane wprowadzenie liczby całkowitej U.

õ

Wygeneruj tablicę liczb całkowitych od 1do U.

fj

Filtruj ( f) liczby pierwsze.

w

Rewers.

æ_

Zwraca pierwszy element, który zwraca prawdziwą wartość (w tym przypadku 1) po przejściu przez funkcję, która sprawdza, czy ...

sø666

Liczba całkowita przekonwertowana na string ( s) zawiera ( ø) 666.


Szybsza alternatywa, 15 bajtów

Ponownie, biorąc pod uwagę, że pierwotnie istniała premia uzależniona od czasu, oto alternatywne i znacznie szybsze rozwiązanie, którego nie mogę dalej grać w golfa.

U-@j *U´sø666}a

Sprawdź to


2

PowerShell , 128 bajtów

param($n)function f($a){for($i=2;$a-gt1){if(!($a%$i)){$i;$a/=$i}else{$i++}}}for(){if($n-match666-and($n-eq(f $n))){$n;exit}$n--}

Wypróbuj online!

Program PowerShell nie ma żadnych wbudowanych głównych faktoryzacji, więc pożycza kod z mojej odpowiedzi na temat znajomych Prime Factors .

Bierzemy dane wejściowe $n, a następnie deklarujemy nowy, function fktóry oblicza czynniki wejściowe $a. Jeśli dane wejściowe $asą liczbą pierwszą, to właśnie zwróci $a.

Główną częścią programu jest nieskończona for()pętla. Wewnątrz pętli sprawdzamy, czy $n -matches jest 666i czy $njest liczbą pierwszą (tzn. Czy $npasuje do wszystkich czynników $n). Jeśli tak, to umieszczamy $ngo w potoku i exit, z niejawnym wynikiem. W przeciwnym razie zmniejszamy $n--i kontynuujemy pętlę.


Trimmed mine version down and just managed to hit half your byte count :D - codegolf.stackexchange.com/a/140539/571
TessellatingHeckler

2

Python 2, 77 76 bytes

Edit: -1 byte thanks to @Mr.Xcoder

Slow running time, runs in O(n^2)

lambda x:max(q for q in range(x+1)if"666"in`q`*all(q%t for t in range(2,q)))

Try it online!

Another 76 bytes solution

lambda x:max(q*("666"in`q`*all(q%t for t in range(2,q)))for q in range(x+1))

Try it online!

With SymPy 73 bytes

lambda x:max(q for q in primerange(0,x+1)if"666"in`q`)
from sympy import*

Try it online!


76 bytes: lambda x:max(q for q in range(x+1)if"666"in`q`*all(q%t for t in range(2,q))) - use max() instead of [][-1]
Mr. Xcoder

2

PowerShell, 71 69 64 bytes

param($s)for(;$s-notmatch666-or(2..($s/2)|?{!($s%$_)});$s--){}$s

Try it online!

  • 328765 takes ~30 seconds on my machine, but times out the 60 second limit on Tio.run.

  • 678987 takes ~1.5 minutes.

  • 969696 takes ~4.5 minutes.

Clever way of doing the factors.
AdmBorkBork

2

MATL, 16 bytes

ZqP"@V'666'Xf?@.

Try it at MATL Online

Explanation

         Implicitly grab input (n)
Zq       Compute the primes up to n (output is in increasing order)
P        Flip the array (so larger primes come first)
"        For each prime
  @V     Convert it to a string
  '666'  Push the string literal '666' to the stack
  Xf     Find the location of '666' in the prime
  ?      If it was present...
    @.   Push it to the stack and break
         Implicitly display the stack contents

2

C++ 389 bytes

#include <iostream>
#include <boost/multiprecision/cpp_int.hpp>
#include <boost/multiprecision/miller_rabin.hpp>
using namespace boost::random;typedef boost::multiprecision::cpp_int Z;int main(int,char**v){mt19937 m(clock());independent_bits_engine<mt11213b,256,Z>g(m);Z n{v[1]},p;while(p++<=n)if(miller_rabin_test(p,25,g)&&p.convert_to<std::string>().find( "666" )!=-1)std::cout<<p<<" ";}

This is a full program!
You'll need Boost to compile it. (Or copy and paste into your favorite online C++ shell.)
Run it from the command-line giving n as argument.

Ungolfed:

#include <iostream>
#include <boost/multiprecision/cpp_int.hpp>
#include <boost/multiprecision/miller_rabin.hpp>
using namespace boost::random;

typedef boost::multiprecision::cpp_int integer;

int main( int argc, char** argv )
{
  mt19937 mt( clock() );
  independent_bits_engine <mt11213b, 256, integer> rng( mt );

  integer input {argv[ 1 ]};
  integer possible;

  while (possible++ <= input)
    if (
      // is_prime( possible )
      miller_rabin_test( possible, 25, rng )
    && 
      // possible has "666" in it
      (possible.convert_to <std::string> ().find( "666" ) != std::string::npos))

    std::cout << possible << " ";
}

Shortcuts were made in terms of random number testing. The original code started testing possible primes at 6661 and incremented by two. You'll also get a compiler warning because of that (-1) there instead of npos.

Still, this runs pretty quickly. It only took about 40 seconds to find all 214 satan primes under 1,000,000 on my old AMD Sempron 130.

:^D


2

Bash + bsd-games package, 33

  • 2 bytes saved thanks to @FedericoPoloni.
primes 2 $[$1+1]|grep 666|tail -1

Try it online.


You can save 1 byte if you replace the last two commands with tail -n1.
Federico Poloni

@FedericoPoloni duh - can't believe I forgot tail here. In fact tail -1 is even 1 less.
Digital Trauma

1

Python 3, 85 83 80 bytes

Halvard's is 4 bytes shorter because it's done in Python 2.

lambda k:max(x for x in range(k+1)if"666"in str(x)*all(x%i for i in range(2,x)))

Try it online!

Give it some time, it's extremely slow because of its O(n^2) complexity.


1

JavaScript (ES6), 55 54 bytes

-1 byte thanks to @ThePirateBay.

f=n=>/666/.test(d=n)&eval("while(n%--d);d<2")?n:f(n-1)

Very slow with large inputs. Primality test adapted from this code golf answer.

Timings

  • Input 10000 took 10 seconds
  • Input 328765 took 3 minutes
  • Input 678987 took 9 minutes
  • Input 969696 took 16 minutes

Tests

Some of these will hang your browser for several minutes.

Faster Version, 56 bytes

Completes each test case in under a second.

f=n=>/666/.test(n)&&eval("for(d=2;n%d++;);d>n")?n:f(n-1)

;[6662, 10000, 328765, 678987, 969696].forEach(n=>console.log(`f(${n}) -> ${f(n)}`))


2
You should never do that. This is code golf and the performance is totally irrelevant. I strongly suggest rolling back to your previous 55 byte answer. Also, you can reduce it to 54 bytes by replacing d==1 with d<2 since n>6661.

52 bytes: f=n=>/666/.test(n)&(g=d=>n%--d?g(d):d<2)(n)?n:f(n-1) but will throw a recursion error for larger numbers.
Shaggy

f=n=>/666/.test(d=n)-eval("while(n%--d);d")?f(n-1):n
l4m2

1

Ruby, 67, 66, 58, 56 bytes

Includes +7 bytes for -rprime

->z{z.downto(1).find{|x|/666/=~x.to_s&&x.prime?}}

It's pretty fast, computing values up to ~2^52 in about a second and 2^64 in under 5 minutes (2011 MBP, Ruby 2.3.1).


1

Stax, 10 bytes

ü>:Ñb/VP6─

Run and debug it

Explanation (unpacked):

^w:pc$666$#! Full program, implicit input-parsing
^            Increment input
 w           do-while:
  :p           Previous prime
    c$         Copy and stringify
      666$     Push "666"
          #    Number of occurences
           !   Logical not
             Implicit output

Nice program. Thanks for trying stax. FYI, it's also possible to do multiple cases by using the "Separator" option like this
recursive

@recursive ah, thx
wastl

0

PHP, 148 bytes

<?php $p=[2];$s=[];for($i=3;$i<=$argv[1];$i++){foreach($p as $q)if($i%$q===0)continue 2;$p[]=$i;if(strpos($i,'666')!==false)$s[]=$i;}echo end($s);?>

Try it online!



0

C# (.NET Core), 117 115 112 bytes

f=>{for(int i=f;i>1;i--){int p=1,j=2;while(j<i)if(i%j++<1)p=0;if(p>0&$"{i}".Contains("666"))return i;}return 0;}

Try it online!

  • 2 bytes saved by removing unnecessary braces.
  • 3 bytes saved by combining int declarations.

I'm sure this could be made shorter; maybe by recursively calling func f and removing the outer for-loop.

Recursive Approach, 85 bytes

i=>{int p=1,j=2;while(j<i)if(i%j++<1)p=0;return p>0&$"{i}".Contains("666")?i:f(--i);}

Try it online!

I'm unsure how well this approach fits within the bounds of code-golf due to having to set the Func<int,int> f = null first, and that f is called again, but not counted towards the bytes. Any clarification would be appreciated.

Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.