ZŁAMANY KLUCZ ZAMKNIĘTY FIASCO

25

Niektórzy z twoich pracowników mają zepsute klawisze Capslock i jesteś zbyt tani, aby je wymienić. Pomóż im, tworząc najkrótszy możliwy program do poprawienia ich pracy! Po prostu przekonwertuj każdy znak w danym ciągu z wielkich na małe i odwrotnie ... ale jest pewien zwrot!

Jesteś również bardzo podekscytowany świętami Bożego Narodzenia! Zostawisz więc mały „błąd”, który nie koryguje liter znajdujących się w ciągach Christmas(bez rozróżniania wielkości liter).

Wkład

Do wprowadzania danych użyjesz jednego łańcucha (lub tablicy bajtów), który może zawierać znaki nowej linii i znaki ascii między 0x20 a 0x7e ( - ~). Nie musisz się martwić o powrót karetki lub inne znaki w łańcuchu.

Wydajność

Wynik powinien zawierać tylko podany ciąg znaków z zamienionymi dużymi i małymi znakami (i oczywiście błąd świąteczny!). Może zawierać maksymalnie jeden dodatkowy biały znak.

Christmas Bug

Wyjaśnijmy to na przykładzie:

Input: i CAN HARDLY WORK LIKE THIS please GET ME A NEW KEYBOARD FOR cHRISTMAS
Output: I Can HaRdly work lIke thiS PLEASE geT Me A new keyboard for ChriStmas

canzawiera „c”, które jest pierwszą literą Bożego Narodzenia, więc to się nie zmienia. Następna litera w Christmasto „h”, która jest w hardly(która również zawiera „r”), więc to się nie zmienia, itd. ChristmasSama ma tylko jedną literę bez zmian, ponieważ do czasu, gdy kod tam osiągnie, faktycznie szuka „s”, a nie „c”.

Gdy sekwencja zostanie znaleziona, powinna zacząć od nowa od „c” i zacząć iterację Christmasjeszcze raz. Więc ChristmasChristmaspozostanie niezmieniony.

Przypadki testowe

Input: Hello World!
Output: hELLO wORLD!

Input: I like pie :)
Output: i LIKE PIE :)

Input: hELP my KeYboarD
       iS BROKEN
Output: Help MY kEyBOARd
        Is broken

Input: cHRISTMAS IS COMING REALLY SOON!
Output: cHRISTMAS is Coming really soon!

Input: C is the first letter in cHRISTMAS
Output: C IS ThE FIrST LETTER iN ChriSTMAS

Zwycięzca

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

redstarcoder
źródło
5
To „brak wbudowanych rozwiązań, które rozwiązałyby większość wyzwań”, jest dość dziwnym ograniczeniem. I czy „przypadek zamiany” naprawdę spowoduje tak wiele problemów, gdy połowa wyzwania określa, które litery nie są w „święta”?
ATaco,
@ATaco, dodałem go w ostatniej chwili z powodu opinii na temat piaskownicy, zgadzam się jednak, więc go usunąłem.
redstarcoder,
Ponadto, w przypadku testowym 3, zamieniłeś pierwszą godzinę, kiedy są święta.
ATaco,
@ATaco szuka Christmassekwencyjnie, więc „h” jest ignorowane, dopóki nie znajdzie „c”, następnie szuka „h”, następnie „r” itd.
redstarcoder,

Odpowiedzi:

9

05AB1E , 16 bajtów

Dzięki Emignie za uratowanie bajtu i naprawienie błędu!

vyÐl'ŒÎ¾èQi¼ëš}?

Wyjaśnienie:

vy                # For each character in the string...
  Ð               #   Triplicate that character
   l              #   Convert to lowercase
    'ŒÎ           #   Compressed version of "christmas"
       ¾          #   Push the counting variable (let's call this N)
        è         #   Get the nth character of "christmas", with modular indexing
         Qi   }   #   If equal...
           ¼      #      N += 1
            ë     #   Else...
             š    #      Swapcase
               ?  #   Print that character

Wykorzystuje kodowanie CP-1252 . Wypróbuj online!

Adnan
źródło
1
Czy to działa z nowymi liniami?
redstarcoder,
@redstarcoder Ups, tak się nie stało. Teraz jest naprawione.
Adnan
2
To wygląda jak blichtr. : D
Tytus
1
Dane wyjściowe są niepoprawne (spróbuj na przykład Święta Bożego Narodzenia jako dane wejściowe), ale jeśli uje usuniesz , powinno działać.
Emigna,
1
@Izyzy 05ab1e istnieje od bardzo dawna.
Pavel
5

V , 38 , 36 bajtów

ÄVumaOchristmasòÉf2x`a@"maj~HòHdjV~

Wypróbuj online! (zawiera dane wejściowe i oczekiwane dane wyjściowe do porównania)

Kiedy zobaczyłem to po raz pierwszy, pomyślałem, że będzie to niezwykle łatwe. W rzeczywistości, gdyby nie było na „Boże Narodzenie” błąd, to będzie tylko 2 bajty: V~. Świąteczny błąd znacznie utrudnia uzyskanie bardzo hackerskiej odpowiedzi.

Jak zwykle, zrzut heksowy:

00000000: c456 756d 614f 6368 7269 7374 6d61 731b  .VumaOchristmas.
00000010: f2c9 6632 7860 6140 226d 616a 7e48 f248  ..f2x`a@"maj~H.H
00000020: 646a 567e                                djV~
DJMcMayhem
źródło
Chciałbym dowiedzieć się więcej o V.
ckjbgames
@ckjbgames Fajnie, chętnie odpowiem na wszelkie pytania! Zawsze możesz pingować mnie w pokoju vim-golf . W tej chwili pracuję nad tym, aby V trochę łatwiej było nauczyć się / stworzyć samouczek.
DJMcMayhem
4

PHP, 113 110 102 bajtów

while($o=ord($c=$argv[1][$i++]))echo chr(32|$o==ord(christmas[$k%9])?$o|0&$k++:ctype_alpha($c)*32^$o);

pobiera dane wejściowe z argumentu pierwszego wiersza poleceń. Uruchom z -r.

awaria

while($o=ord($c=$argv[1][$i++]))// loop through string characters
    echo chr(
        32|$o==ord(christmas[$k%9]) // if $c equals next character in "christmas"
            ?$o|0&$k++              // no change, increase "christmas" index
            :ctype_alpha($c)        // else if $c is a letter
                    *32^$o          // toggle bit 5 of the ascii code
        );
Tytus
źródło
2

MATL , 36 30 bajtów

"@tk'schristma'H)=?HQXHx}Yo]&h

Ciągi znaków nowego wiersza należy zdefiniować, 10łącząc się z kodem ASCII (patrz przykład w łączu z przypadkami testowymi).

Wypróbuj online! Lub sprawdź wszystkie przypadki testowe .

Wyjaśnienie

"              % Implicit input of a string. For each character in that string
  @            %   Push current character
  tk           %   Duplicate and convert to lowercase
  'schristma'  %   Push string. This is 'Christmas' in lowercase and circularly
               %   shifted such that the 'c' is in the second position
  H            %   Push contents of clipboard H, which is initiallized to 2.
               %   This value will be gradually increased when a new character
               %   from the the sequence is found
  )            %   Get character from 'schristma' at that (modular) position
  =            %   Are they equal?
  ?            %   If so
    HQ         %     Push contents of clipboard H and add 1
    XHx        %     Copy into clipboard K and delete
  }            %   Else
    Yo         %     Change case
  ]            %   End
  &h           %   Concatenate stack contents horizontally. This gives a string 
               %   with all characters processed up to now
               % Implicit end. Implicit display
Luis Mendo
źródło
2

Pyke, 31 25 bajtów

FD.dґ~o@Dl3+{DIoK)R!Il3

Wypróbuj tutaj!

niebieski
źródło
Czy to działa z nowymi liniami?
redstarcoder,
@redstarcoder, jeśli uciekniesz przed nimi \ni otoczysz wejście, "wtedy tak
Blue
2

Perl 6 , 84 bajtów

{my $i=0;[~] (.lc~~"christmas".comb[$i%9]??(++$i&&$_)!!.ord>90??.uc!!.lc for .comb)}
smls
źródło
2

C # 197 bajtów

Nie wygrasz z tym, ale mam nadzieję, że najmniejsza implementacja C #, która działa ...

string C(string s){int i=0,j=0;var r="";for(;i<s.Length;){char c=s[i++],o=(char)32;if(c=="christmas"[j]|c=="CHRISTMAS"[j])j=j>7?0:j+1;else if(c>64&c<91)c+=o;else if(c>96&c<123)c-=o;r+=c;}return r;}

Wyjaśnienie:

string C(string s)
{
    // define our two index ints
    // i for indexing across the input string
    // j for indexing across christmas
    int i = 0, j = 0;

    // r is our return string
    var r = "";

    // declare our loop
    // skip the initialisation and afterthought
    for (; i < s.Length;)
    {
        // get our current character c, and increment index i
        // initial our offset char o (difference between upper and lower case)
        char c = s[i++], o = (char)32;

        // check if c is the current character in our christmas bug
        if (c == "christmas"[j] | c == "CHRISTMAS"[j])
            // increment j (or reset to 0)
            j = j > 7 ? 0 : j + 1;

        // else if c is an upper case char
        else if (c > 64 & c < 91)
            // add our offset to make it lower case
            c += o;

        // else if c is lower case
        else if (c > 96 & c < 123)
            // subtract our offset to make it upper case
            c -= o;

        // append c to our return string r
        r += c;
    }

    return r;
}
Erresen
źródło
2

JavaScript, 122 118 114 107 104 93 bajtów

f=
s=>s.replace(/./g,c=>(k=c.toLowerCase())=='christmas'[i%9]?++i&&c:k!=c?k:c.toUpperCase(),i=0)


F=s=>console.log(f(s))
F(`Hello World!`)
F(`I like pie :)`)
F(`hELP my KeYboarD
       iS BROKEN`)
F(`cHRISTMAS IS COMING REALLY SOON!`)
F(`C is the first letter in cHRISTMAS`)

  • 11 bajtów off dzięki @Neil.
Washington Guedes
źródło
Czy nie możesz k!=c?k:c.toUpperCase()zaoszczędzić kilka bajtów?
Neil
1

Perl 6 , 80 bajtów

{my$i=0;S:g{.?<!{'christmas'.comb[$i%9]eq$/.lc&&++$i}>}=$/eq$/.lc??$/.uc!!$/.lc}

Spróbuj

{   # bare block lambda with implicit parameter 「$_」

  my $i = 0;             # counter

  S                      # substitute and return ( implicitly against 「$_」 )
  :global
  {
    .                    # any char
    ?                    # work around a bug where 「$/」 doesn't get set

    <!{                  # fail this match if this block returns True
      'christmas'.comb\  # a list of the characters of 「christmas」
      [ $i % 9 ]         # grab a char from the list
      eq                 # is it equal to
      $/.lc              # the lowercase version of the char
      &&                 # if so
      ++$i               # increment 「$i」 ( result is True )
    }>

  }

  =                      # for each matched char

  $/ eq $/.lc            # is it lowercase?
  ?? $/.uc               # the uppercase it
  !! $/.lc               # otherwise lowercase it
}
Brad Gilbert b2gills
źródło
Nie sądzę, aby pominięcie tego miejsca my $i=0;było legalne. I nie zdziwiłbym się, gdyby było więcej błędów składniowych związanych z białymi znakami.
bb94
1
@ bb94 Dosłownie zamieściłem link do strony, na której będzie działał kod. Jeśli nie wierzysz, że to zadziała, spróbuj tego. Mam na myśli, że pisałem, $/ eq $/.lca nie po $/.lc eq $/to, by wcześniej usunąć tę przestrzeń eq.
Brad Gilbert b2gills,
@ bb94 Mogę potwierdzić, że działa na połączonym kompilatorze.
redstarcoder
1

Java 7, 200 bajtów

String c(char[]a){String r="";int i=0,s;Character l='a';for(char c:a)if((s="christma".indexOf(l=l.toLowerCase(c)))==i|i>7&s==4){r+=c;i=i>7?0:i+1;}else r+=l.isUpperCase(c)?l:l.toUpperCase(c);return r;}

Brzydki, ale działa .. Zdecydowanie można bez wątpienia grać w golfa .. Jestem zardzewiały ...

Nie golfowany:

String c(char[] a){
  String r = "";
  int i = 0,
      s;
  Character l = 'a';
  for(char c : a){
    if((s = "christma".indexOf(l = l.toLowerCase(c))) == i) | i > 7 & s == 4){
      r += c;
      i = i > 7
           ? 0
           : i+1;
    } else{
      r += l.isUpperCase(c)
       ? l
       : l.toUpperCase(c);
    }
  }
  return r;
}

Kod testowy:

Wypróbuj tutaj.

class M{
  static String c(char[]a){String r="";int i=0,s;Character l='a';for(char c:a)if((s="christma".indexOf(l=l.toLowerCase(c)))==i|i>7&s==4){r+=c;i=i>7?0:i+1;}else r+=l.isUpperCase(c)?l:l.toUpperCase(c);return r;}

  public static void main(String[] a){
    System.out.println(c("i CAN HARDLY WORK LIKE THIS please GET ME A NEW KEYBOARD FOR cHRISTMAS".toCharArray()));
    System.out.println(c("Hello World!".toCharArray()));
    System.out.println(c("I like pie :)".toCharArray()));
    System.out.println(c("hELP my KeYboarD\niS BROKEN".toCharArray()));
    System.out.println(c("cHRISTMAS IS COMING REALLY SOON!".toCharArray()));
    System.out.println(c("C is the first letter in cHRISTMAS".toCharArray()));
  }
}

Wydajność:

I Can HaRdly work lIke thiS PLEASE geT Me A new keyboard for ChriStmas
hELLO wORLD!
i LIKE PIE :)
Help MY kEyBOARd
Is broken
cHRISTMAS is Coming really soon!
C IS ThE FIrST LETTER iN ChriSTMAS
Kevin Cruijssen
źródło
2
Java pokonuje Haskell i C #!
Pavel
1

Python 100 bajtów

def a(s,i=0,g=''):
 for c in s:a=c.lower()=='christmas'[i%9];i+=a;g+=[c.swapcase(),c][a]
 return g
Cormac
źródło
1

Rubinowy, 63 + 1 = 64 bajty

Używa -pflagi.

i=0;gsub(/./){|c|c=~/#{"christmas"[i%9]}/i?(i+=1;c):c.swapcase}
Wartość tuszu
źródło
0

C # 239 znaków

var s=Console.ReadLine().ToCharArray();int j=0,i=0;var c="christmas";for(;j<s.Length;j++)if(s[j]==c[i%9]|s[j]==(c[i%9]-32))i++;else if(s[j]>64&s[j]<91)s[j]=(char)(s[j]+32);else if(s[j]>96&s[j]<123)s[j]=(char)(s[j]-32);Console.WriteLine(s);

bardziej wyraźna wersja:

var s = Console.ReadLine().ToCharArray();
int j = 0,i = 0;
var c = "christmas";
for (var j = 0; j < s.Length; j++)
   if (s[j] == c[i%9]|s[j] == (c[i%9] - 32))// non case sensitive compare with c 
      i++;//next char in christmas
   else
      if (s[j] > 64 & s[j] < 91)//if between A and Z
         s[j] = (char)(s[j] + 32);//convert to a-z
      else
         if (s[j] > 96 & s[j] < 123)//if between a and z
            s[j] = (char)(s[j] - 32);//convert to A-Z
Console.WriteLine(s);

jest to dość naiwne rozwiązanie i prawdopodobnie można je ulepszyć (może możemy zezwolić na niejawną konwersję na char?).

zakłada się, że znajduje się w funkcji, odczytuje z konsoli (standardowe wejście) i zapisuje w niej (standardowe wyjście).

edit: Char.IsUpper (s [j]) jest o 2 bajty dłuższy niż s [j]> 64 && s [j] <91, Char.ToUpper jest także dłuższy niż moja wersja.

satibel
źródło
0

Haskell, 222 207 bajtów

import Data.Char
s=(+(-65)).ord
f=(`divMod`32).s
l=[['a'..'z'],['A'..'Z']]
c=cycle$map s"CHRISTMAS"
k _[]=[]
k(a:b)(x:y)|isAlpha x=let(d,m)=f x in if(m==a)then(x:k b y)else(l!!d!!m:k(a:b)y)|1>0=x:k(a:b)y
main=interact$k c

zaktualizowano:

import Data.Char
s=(+(-65)).ord
k _[]=[]
k(a:b)(x:y)|isAlpha x=let(d,m)=s x`divMod`32 in if(m==a)then(x:k b y)else([['a'..'z'],['A'..'Z']]!!d!!m:k(a:b)y)|1>0=x:k(a:b)y
main=interact$k$cycle$map s"CHRISTMAS"

Jak to działa:

s=(+(-65)).ord

sx = wartość ASCII dla x - wartość ASCII dla „A”

f=(`divMod`32).s

f (sx) = (0, sx) dla wielkich liter, (1, (s x-32)) dla małych liter

l=[['a'..'z'],['A'..'Z']]

równoległa lista liter, indeksowana przez f (małe litery-> 1-> wielkie litery, wielkie litery-> 0-> małe litery)

c = cycle $ map s "CHRISTMAS"

powtórzono nieskończoną listę wartości ascii wielkich świąt Bożego Narodzenia

k _ []=[]

skrzynka podstawowa

k (a:b) (x:y) | isAlpha x = let (d,m) =f x
                             in if m == a
                                then x : k b y
                                else (l!!d)!!m : k (a:b) y
              | 1 > 0 = x : k (a:b) y

zwracaj znaki niealfanumeryczne i zachowaj literę, jeśli jej wartość s jest taka sama jak bieżąca litera Bożego Narodzenia (przejście do następnej litery), w przeciwnym razie przekonwertuj ją na drugą literę i kontynuuj

main=interact$k c

IO

archaephyrryx
źródło