Dlaczego 6 bało się 7?


61

Dlaczego 6 bało się 7? Ponieważ 7 8 9!

Podany ciąg znaków stosuje następujące przekształcenia:

  • Jeśli obok 7 jest 6, usuń 6 (6 boi się 7)
  • Jeśli pojawi się sekwencja „789”, usuń 8 i 9 (7 zjadł 9)

(Jeśli się nie mylę, nie ma znaczenia, w jakiej kolejności przeprowadzacie transformacje)

Stosuj te transformacje, aż przestaniesz.

Przykład:

78966

Najpierw widzimy „789”, więc ciąg staje się „766”. Następnie widzimy „76”, więc wyjmujemy 6, a ciąg staje się „76”. Następnie ponownie widzimy „76”, więc pozostaje nam „7”.

Przypadki testowe:

  • 987=> 987(Nie w odpowiedniej kolejności. Nic nie robi.)
  • 6 7=> 6 7(Biała spacja działa jako bufor między 6 a 7. Nic się nie dzieje)
  • 676 => 7
  • 7896789 => 77
  • 7689 => 7
  • abcd => abcd

130
Dlaczego Vista obawiała się 7? Ponieważ 7 8 10.
lirtosiast

2
Kolejny przypadek testowy 68978966897896=>68977
Brad Gilbert b2gills,

19
@ThomasKwa Och, rozumiem: Microsoft pominął Windows 9, ponieważ szli razem z zagadką. ;)
ETHproductions

43
Dlaczego boisz się, że siódemka ma pięć lat? Ponieważ sześć siedem osiem. --Yoda
Jakuje

2
Sześciu bało się siódemki, ponieważ siódemka miała zimne, martwe oczy.
Conor O'Brien

Odpowiedzi:



12

JavaScript ES6, 29 bajtów

s=>s.replace(/6*7(89|6)*/g,7)

Test:

f=s=>s.replace(/6*7(89|6)*/g,7)
;`987 -> 987
6 7 -> 6 7
676 -> 7
7896789 -> 77
7689 -> 7
abcd -> abcd`
.split`\n`.every(t=>(t=t.split` -> `)&&f(t[0])==t[1])

12
Świetnie, a ponieważ zjedzono 9, masz tylko 2 bajty i wygrywasz z tą odpowiedzią: P
Pierre Arlaud

12

Java, 126 81 66 58 bajtów

Dzięki @GamrCorps za udostępnienie wersji kodu lambda!

Dzięki @ user902383 za wskazanie sztuczki polegającej na autoboksowaniu!

...tak.

Jest faktycznie dłuższy niż się spodziewałem - Java zamienia elementy w ciągach replaceAll()jeden raz na dopasowanie, nie wielokrotnie, dopóki nie przestanie się zmieniać. Musiałem więc użyć fantazyjnej pętli.

Formularz lambda:

x->{for(;x!=(x=x.replaceAll("67|76|789","7")););return x;}

Formularz funkcji:

String s(String x){for(;x!=(x=x.replaceAll("67|76|789","7")););return x;}

Testowany niepoznany kod:

class B{
    public static void main(String[]a){
        System.out.print(new B().s(a[0]));
    }
    String s(String x){for(;x!=(x=x.replaceAll("67|76|789","7")););return x;}
}

2
Dlaczego nie pójść z lambda? Zaoszczędzi co najmniej 15 bajtów
GamrCorps

@GamrCorps Nie wiem, jak to sformułować - nigdy nie używaj funkcji.
Addison Crump,

1
jaki jest sens interfejsu, a nie klasy?
eis

3
Interfejs @eis eliminuje potrzebę deklarowania głównego jako publicznego, co daje najmniejszą przewagę. Zobacz: codegolf.stackexchange.com/a/64713/44713
Addison Crump

1
@ user902383 Zmniejszenie, które wprowadzasz, polega na zmianie .equalsna !=, co nie robi tego samego. ==(lub !=) porównuje według położenia szesnastkowego obiektu, a nie według wartości. W przeciwnym razie ma taką samą długość. while()ma 7 bajtów, for(;;)ma 7 bajtów.
Addison Crump,


8

Perl 6 , 19  18 bajtów

{S:g/6*7[6|89]*/7/} # 19 bytes

$ perl6 -pe 's:g/6*7[6|89]*/7/' # 17 + 1 = 18 bytes

(Zauważ, że [6|89]wersja, (6|89)której nie można przechwycić, jest napisana tak, jak (?:6|89)w Perlu 5. Sposób <[6|89]>pisania tego, co napisane jest [6|89]w Perlu 5)

stosowanie:

$ perl6 -pe 's:g/6*7[6|89]*/7/' <<< '
987
6 7
6676689
7896789
7689
abcd
68978966897896
79|689
'
987
6 7
7
77
7
abcd
68977
79|689

Nie znam Perla 6, ale zakładam, że jest to wielokrotna zamiana. Jeśli 6*i [6|89]*nie pasują do niczego, co powstrzymuje 7bycie zastąpionym 7ad infinitum?
Cyfrowy uraz

2
@DigitalTrauma Zamienia się 7z, 7a następnie zaczyna od nowa na następnej pozycji, działając do końca. :gjest skrótem od :globalnie repeat until it doesn't match anymore.
Brad Gilbert b2gills,

1
@DigitalTrauma Aby zabrać się s/67|76|789/7/do pracy 667, musiałbym napisać to jako coś w stylu: while s/67|76|789/7/ {}co oczywiście nigdy by się nie skończyło, gdybyś napisał to tak, while s/6*7[6|89]*/7/ {}jak się spodziewałeś. Również koniec poprzedniego komentarza może odejść jako wredny, nie taki był jego zamiar
Brad Gilbert b2gills

1
Czy nie []należy tego zmienić na ()? Nie chcesz dopasowywać rur lub 79999.
jwodder

1
@jwodder No []to nie przechwytująca wersja Perla 6 (), o której myślisz, napisane jak <[6|89]>w Perlu 6.
Brad Gilbert b2gills


4

Perl 5 , 17 bajtów

perl -pe 's/6*7(6|89)*/7/g' # 16 + 1

stosowanie:

$ perl -pe 's/6*7(6|89)*/7/g' <<< '
987
6 7
6676689
7896789
7689
abcd
68978966897896
'
987
6 7
7
77
7
abcd
68977

4

Mathematica, 52 bajty

StringReplace[#,"67"|"76"|"789"->"7"]&~FixedPoint~#&

Wyjaśnienie:

                                                   &   A function returning
                                     &                   a function returning
              #                                            its first argument
StringReplace[ ,                    ]                     with
                "67"                                        "67"
                    |                                      or
                     "76"                                   "76"
                         |                                 or
                          "789"                             "789"
                               ->                         replaced with
                                 "7"                       "7"
                                    ~FixedPoint~        applied to
                                                #        its first argument
                                                        until it no longer changes.

8
Kod do gry w golfa jest wyraźniejszy niż kod objaśniający .. :)
Rob

@Rob Haven nie przedstawił wcześniej wielu wyjaśnień, dążąc do systematycznego podejścia.
LegionMammal978

Po prostu drażniłem się, kolego :)
Rob

3

Rdza, 96 bajtów

fn f(mut s:String)->String{for _ in 0..s.len(){for r in&["67","76","789"]{s=s.replace(r,"7")}}s}

Beznadziejnie długi, jak zwykle dla Rust ...

Nie golfowany:

fn seven_ate_nine(mut str: String) -> String {
    for _ in 0..str.len() {
        for to_replace in &["67","76","789"] {
            str = str.replace(to_replace, "7");
        }
    }
    s
}

Przynajmniej nie jest to Java

3

Emacs Lisp, 59 bajtów

(lambda(s)(replace-regexp-in-string"6*7\\(6\\|89\\)*""7"s))

Staje się nieco jaśniejszy ze spacjami:

(lambda (s) (replace-regexp-in-string "6*7\\(6\\|89\\)*" "7" s))

3

Rubinowy, 27 bajtów

To rozwiązanie pochodzi z komentarzy, dzięki uprzejmości Brada Gilberta b2gills .

->s{s.gsub /6*7(6|89)*/,?7}

Rubinowy, 37 bajtów

(stare rozwiązanie)

To rozwiązanie wykorzystuje fakt, że nigdy nie będziesz musiał zamieniać więcej razy niż znaków w ciągu.

->s{s.chars{s.sub! /67|76|789/,?7};s}

Możesz użyć charszamiast size.timeszapisać kilka bajtów.
Klamka

Czy Ruby nie ma flagi globalnej dla podstawienia wyrażenia regularnego, czy też potrzeba więcej bajtów, aby włączyć?
Brad Gilbert b2gills,

@ BradGilbertb2gills, w Ruby jest jak w Awk: istnieją osobne sub()i gsub()metody, aby zastąpić najpierw lub wszystkie. Tak więc globalny jest tylko jedną postacią dłuższą.
manatwork

1
@manatwork W takim razie napisałbym coś w stylu: ->s{s.gsub /6*7(6|89)*/,'7'}i gsubwykonał całą pętlę.
Brad Gilbert b2gills,

Jeśli dobrze rozumiem zasady dotyczące flag wiersza poleceń, możesz zapisać 16 bajtów, używając flagi -p wiersza polecenia -p (+1), dzięki czemu jest on gsub /6*7(6|89)*/,?7używany ruby -pe "gsub /6*7(6|89)*/,?7"łącznie do 20 + 1 bajtów
Alexis Andersen


2

PowerShell, 27 bajtów

$args-replace'6*7(89|6)*',7

e.g.
PS C:\temp> .\ate.ps1 "7689"
7

PS C:\temp> .\ate.ps1 "abcd"
abcd

PS C:\temp> .\ate.ps1 "68978966897896"
68977

Z wykorzystaniem:

  • czyjś wzorzec regularny
  • sposób, w jaki -replaceglobalnie zastępuje domyślnie w PowerShell
  • rozwijanie pętli, w którym zastosuje -regexoperator do tablicy $args, stosując go indywidualnie do wszystkich elementów, i jest tylko jeden element, ponieważ jest tylko jeden parametr skryptu, więc działa OK i możemy uniknąć konieczności indeksowania elementu [0].

Zrobiłoby to nowa poprzednia próba przed realizacją globalnego zastąpienia; 74 bajty budowania łańcucha „-replace -replace -replace” przy użyciu mnożenia ciągu znaków tyle razy, ile wynosi długość ciągu, a następnie eval ():

"'$($args)'"+("{0}6|6(?=7)'{0}89'"-f"-replace'(?<=7)")*$args[0].Length|iex

(Z odrobiną podstawienia łańcucha w celu skrócenia liczby zamienników).


2

CJam, 70 64 bajtów

Dzięki @Peter Taylora do cięcia {"789":I}{"76:":I}?do"789""76"?:I

"67":Iq:A{AI#:B){AB<7+A{BI,+}~>+s:A];}{"76"I={"789":I}{"76":I}?];}?}/A

"67":Iq:A{AI#:B){AB<7+A{BI,+}~>+s:A];}{"76"I="789""76"?:I];}?}/A

Wiem, że prawdopodobnie można by grać o wiele dalej i twoja pomoc byłaby bardzo mile widziana, ale szczerze mówiąc, po prostu cieszę się, że udało mi się uzyskać odpowiedź. To była moja pierwsza próba napisania CJam.

Wyjaśnienie:

"67":I                e# Assign the value of 67 to I
q:A                   e# Read the input and assign to A
{                     e# Opening brackets for loop
    AI#:B)            e# Get the index of I inside A and assign to B. The increment value by 1 to use for if condition (do not want to process if the index was -1)
    {                 e# Open brackets for true result of if statement
        AB<           e# Slice A to get everything before index B
        7+            e# Append 7 to slice
        A{BI,+}~>     e# Slice A to get everything after index B plus the length of string I (this will remove I entirely)
        +s:A          e# Append both slices, convert to string, and assign back to A
        ];            e# Clear the stack
    }                 e# Closing brackets for the if condition
    {                 e# Open brackets for false result of if statement
        "76"I=        e# Check if I is equal to 76
        "789"         e# If I is 76, make I 789
        "76"?:I       e# If I is not 76, make I 76
        ];            e# Clear the stack if I does not exist inside A
    }?                e# Closing brackets for false result of if statement
}/                    e# Loop
A                     e# Output A

Sam nie próbowałem tego pytania, więc nie jestem pewien, czy jest to najlepsze podejście, ale jeśli chcesz podzielić i połączyć, spójrz na /i *. Pamiętaj również, że myślenie w kategoriach stosów, gdy jesteś przyzwyczajony do języków podobnych do C, wymaga pewnej adaptacji. Np. {"789":I}{"76":I}?Może wyciągnąć zadanie, aby zostać "789""76"?:I, na które można dalej grać w golfa 78976`3/?:I.
Peter Taylor,

Dziękuję Ci! Nie mogłem jednak zrozumieć, jak wykorzystać twoją drugą sugestię.
Conrad Crates,

Przepraszam, mój błąd. 78976`3/daje tablicę ["789" "76"]; wtedy zamiast używać, ?będziesz musiał użyć =do indeksowania; ale jest on skierowany do przodu, więc musiałby być odwrócony indeks, tracąc przewagę.
Peter Taylor,

2

MATL , 17 bajtów

jt"'789|76'55cYX]

Przykład

>> matl
 > jt"'789|76'55cYX]
 > 
> 7896789
77

EDYCJA : Wypróbuj online!

Wyjaśnienie

j                   % input string
t                   % duplicate
"                   % for each character. Iterates as many times as the string length
    '789|76'        % regular expression for replacement
    55c             % string to insert instead: character '7'
    YX              % regexprep
]                   % end for

Działa to poprzez zastosowanie regularnego zastępowania wyrażeń tyle razy, ile znaków ma oryginalny ciąg . To wystarczy, ponieważ każda zamiana zmniejsza liczbę znaków.


1

Poważnie, 29 bajtów

,;l`'7;;"67"(Æ"76"(Æ"789"(Æ`n

Pobiera dane wejściowe jako ciąg cudzysłowu, np "6789". Wypróbuj online (będziesz musiał ręcznie zacytować dane wejściowe).

Wyjaśnienie:

,;l`'7;;"67"(Æ"76"(Æ"789"(Æ`n
,;l                            get input and push its length (we'll call it n)
   `                       `n  call the following function n times:
    '7;;"67"(Æ                   replace all occurrences of "67" with "7"
              "76"(Æ             replace all occurrences of "76" with "7"
                    "789"(Æ      replace all occurrences of "789" with "7"

1

Czw. 26 bajtów

67::=7
76::=7
789::=7
::=

w tym końcowy znak nowej linii.

Dane wejściowe są dołączane do programu przed jego uruchomieniem.
Wyjście jest odczytywane ze stanu programu po jego zakończeniu, podobnie jak maszyna Turinga.
(Thue nie mają strumień wyjściowy, ale trudno używać prawidłowo, więc nie jestem pewien, czy jest to dopuszczalna metoda wyjścia)


Nie wydaje mi się Jeśli masz sposób na STDOUT, musisz. Przepraszam!

Tak, jest to dozwolone zgodnie z meta postem.
geokavel

1

Bash, 102 82 67 (+7)? bajty

wersja extglob

x=$1
while v=${x/@(76|67|789)/7};[ $v != $x ];do x=$v;done
echo $v

Jest to przeznaczone do umieszczenia w pliku i wywołania np bash -O extglob 789.sh 6567678989689789656. (+7)? bajtów jest, jeśli opcja extglob liczy się do bajtów.

Dzięki @BinaryZebra za wskazanie funkcji extglob!


Wersja bez extglob (82 bajty)

x=$1
while v=${x/76/7};v=${v/67/7};v=${v/789/7};[ $v != $x ];do x=$v;done
echo $v

Jest to przeznaczone do umieszczenia w pliku i wywołania np ./789.sh 65678989656.

Wykorzystuje rozszerzenie parametrów do wyszukiwania i zamiany w pętli. Wymieniłem serię rozszerzeń, ponieważ nie znam sposobu na bardziej efektywne łączenie rozszerzeń.


Witamy w PPCG!
Mego

@BinaryZebra Ah, dzięki za @()składnię. Wiedziałem, że musi istnieć sposób na ich połączenie. I @Mego, dzięki za powitanie!
Pooping

1

R, 35 bajtów

cat(gsub("6*7(6|89)*",7,scan(,"")))

Nie wiedziałem, że mogę skorzystać z gsubtego sposobu, wielkie dzięki za każdą odpowiedź, która sprawiła, że ​​nauczyłem się czegoś nowego.


0

PHP 51 znaków

while($s!=$r=str_replace([789,67,76],7,$s)){$s=$r;}

Przypadek testowy napisany długimi rękami

$s = '78966';
while ($s != $r = str_replace([789, 67, 76], 7, $s) )
{
    $s = $r;
}
echo $s; // 7;

Dokonuje to porównania łańcucha i łańcucha zastępuje oba w stanie while. Jeśli warunek jest spełniony, aktualizuje lewą rękę porównania z wynikiem. Daj mi znać o wszelkich ulepszeniach.



0

PHP, 36 bajtów

preg_replace('/6*7(6|89)*/','7',$a);

Wyrażenie regularne, pobiera $ ciąg i zastępuje poprzez wyrażenie.


Parametry GET są niedopuszczalne jako metoda wprowadzania danych w PHP . Musisz albo ustawić tę funkcję i przekazać dane wejściowe jako parametry funkcji, albo uzyskać dane wejściowe z $argvlub STDIN.
Mego

@Mego Wygląda na to, że nie ma zgody co do posta, do którego linkujesz.
user253751,

@immibis Prawidłowo. Wymagany jest konsensus, aby metoda I / O była akceptowalna. Brak jednego oznacza, że ​​jest nie do przyjęcia.
Mego

TL; DR masz poważne wady, jeśli używasz PHP dla codegolf.
HamZa,

0

Clojure, 71 bajtów

Clojure jest mniej niż idealny do gry w golfa ze względu na jego pełną naturę - ale mimo to jest to interesujące ćwiczenie:

Wersja golfowa, wykorzystująca interfejs Java:

(defn f[s](let[x(.replaceAll s "67|76|789" "7")](if(= s x)s(recur x))))

Wersja bez gry w golfa, z wykorzystaniem Java Interop:

(defn six-fears-seven [s]
  (let [x (.replaceAll s "67|76|789" "7")]
    (if (= s x)
      s
      (recur x))))

Wersja „czystego Clojure” bez gry w golfa:

(defn six-fears-seven [s]
  (let [x (clojure.string/replace s #"67|76|789" "7")]
    (if (= s x)
      s
      (recur x))))


0

Python 3, 46 bajtów

import re
lambda s:re.sub(r'6*7(6|89)*','7',s)

0

Japt v2.0a0, 12 bajtów

e/6?7(6|89/7

Wypróbuj online!

Jak to działa

String.ejest funkcją zastępowania rekurencyjnego. Japt 2 ma nową składnię wyrażeń regularnych i automatyczne uzupełnianie nawiasów w wyrażeniach regularnych, co oszczędza tutaj jeden bajt. (W Japt 1.x musieliśmy przekazywać łańcuchy zamiast wyrażeń regularnych, co było trochę niezgrabne.)


0

Dyalog APL , 17 bajtów

'6*7(6|89)*'⎕R'7'

'6*dowolna liczba szóstek,
7 po których następuje siedem
()*' a następnie zero lub więcej sekwencji…
6|89 sześć lub osiem-dziewięć

⎕RR EUmieãæ że z

'7' siódemka


0

05AB1E , 12 bajtów

Δ67‚7:789¬:

Wypróbuj online lub sprawdź wszystkie przypadki testowe .

Wyjaśnienie:

Δ               # Continue doing the following until it no longer changes:
 67             #  Push 67 to the stack
   Â            #  Bifurcate (short for Duplicate & Reverse); which pushes 76 to the stack
               #  Pair them up
     7:         #  Replace all occurrences of 67 or 76 with 7 in the (implicit) input
                #   i.e. 17893762 → 1789372
       789      #  Push 789 to the stack
          ¬     #  Take the head (without popping); which pushes 7 to the stack
           :    #  Replace all 789 with 7
                #   i.e. 1789372 → 17372
                # (And implicitly output the result after the loop)
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.