壊れたCAPSLOCK KEY FIASCO


25

従業員の中には、Capslockキーが壊れているため、交換するには安すぎます。作業を修正するために可能な限り短いプログラムを作成して、彼らを助けてください!与えられた文字列の各文字を大文字から小文字に、またはその逆に単純に変換します...しかし、ひねりがあります!

クリスマスも大興奮です!したがって、Christmas(大文字と小文字を区別しない)シーケンス内の文字を修正しない小さな「バグ」を残すことになります。

入力

入力には、0x20〜0x7e- ~)の改行とASCIIを含む単一の文字列(またはバイトの配列)を使用します。文字列にキャリッジリターンやその他の文字が含まれていることを心配する必要はありません。

出力

出力には、大文字と小文字が入れ替わった文字列のみが含まれている必要があります(そしてもちろんクリスマスのバグです!)。末尾に空白を1つまで含めることができます。

クリスマスバグ

例でこれを説明しましょう。

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

canクリスマスの最初の文字である「c」が含まれているため、変更されません。の次の文字Christmasは「h」で、これはhardly(「r」も含む)であるため、変更されません。Christmasコードはそこに到達するまでに実際に探しているため、変更されません。「c」ではなく「s」。

シーケンスが見つかったら、「c」から最初からやり直し、もう一度繰り返しChristmasます。そのChristmasChristmasままにしておきます。

テストケース

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

勝者

これはので、最短の答えが勝ちです!


5
「ほとんどの課題を解決する組み込み機能がない」というのは、かなり奇妙な制限です。そして、チャレンジの半分がどの文字が「クリスマス」にないのかを特定するときに、「スワップケース」は本当に多くの問題を引き起こすでしょうか?
アタコ16


@ATaco、サンドボックスに関するフィードバックのために土壇場で追加しましたが、同意しましたので削除しました。
redstarcoder 16

また、テストケース3では、クリスマスの最初のhを交換しました。
アタコ16

@ATacoは、それが探しChristmassequencially、それは、「C」を見つけるまで、「H」は等は、「R」は、それが「H」を検索し、無視される
redstarcoder

回答:


9

05AB1E、16バイト

バイトを保存してバグを修正してくれたエミグナに感謝します!

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

説明:

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

CP-1252エンコードを使用します。オンラインでお試しください!


1
これは改行でも機能しますか?
redstarcoder 16

@redstarcoderおっと、そうではなかった。現在修正されています。
アドナン

2
これは見掛け倒しのように見えます。:D
タイタス

1
出力は正しくありません(たとえば、入力としてクリスマスを試してください)が、削除しuても機能するはずです。
エミグナ16

1
@Izzy 05ab1eは長い間存在していました。
パベル

5

V38、36バイト

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

オンラインでお試しください!(比較のための入力と期待される出力を含む)

これを最初に見たとき、それは非常に簡単だと思いました。実際、「クリスマス」のバグではない場合、これは2バイトになりますV~。クリスマスのバグは、非常にハッキーな答えのために、それをかなり難しくします。

いつものように、これはhexdumpです:

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~

Vについてもっと知りたいです。
ckjbgames17年

@ckjbgamesクール、ご質問がありましたらお気軽にお問い合わせください!vim-golfルームでいつでもpingできます。現在、私はVの学習/作成を少しだけ簡単にすることに取り組んでいます。
DJMcMayhem

4

PHP、113 110 102バイト

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

最初のコマンドライン引数から入力を受け取ります。で実行し-rます。

壊す

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
        );

2

MATL36 30バイト

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

改行を含む文字列は、ASCIIコードと連結して定義する必要があります10(テストケースとのリンクの例を参照)。

オンラインでお試しください!または、すべてのテストケースを確認します

説明

"              % 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


2

Perl 6、84バイト

{my $i=0;[~] (.lc~~"christmas".comb[$i%9]??(++$i&&$_)!!.ord>90??.uc!!.lc for .comb)}

2

C#197バイト

これで勝つつもりはありませんが、うまくいけば、動作する最小のC#実装...

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;}

説明:

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;
}

2

JavaScript、122 118 114 107 104 93バイト

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`)

  • @Neilに感謝します。

k!=c?k:c.toUpperCase()数バイト節約するために使用できませんか?
ニール

1

Perl 6、80バイト

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

それを試してみてください

{   # 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
}

スペースを省略することmy $i=0;は合法ではないと思います。そして、空白に関連する構文エラーがもっとあったとしても驚かないでしょう。
bb94 16

1
@ bb94文字通り、コードを実行するサイトへのリンクを含めました。それが実行されると思わない場合は、試してみてください。以前にスペースを削除できるように書いたの$/ eq $/.lcではあり$/.lc eq $/ませんeq
ブラッドギルバートb2gills 16

@ bb94リンクされたコンパイラで動作することを確認できます。
redstarcoder

1

Java 7、200バイト

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;}

glyいですが、それは動作します。間違いなく間違いなくもっとゴルフをすることができます。

ゴルフをしていない:

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;
}

テストコード:

ここで試してみてください。

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()));
  }
}

出力:

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

2
JavaがHaskellとC#を打ち負かす!
パベル

1

Python 100バイト

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

1

ルビー、63 + 1 = 64バイト

-pフラグを使用します。

i=0;gsub(/./){|c|c=~/#{"christmas"[i%9]}/i?(i+=1;c):c.swapcase}

0

C#239文字

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);

より明示的なバージョン:

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);

これはかなりナイーブなソリューションであり、おそらく改善することができます(暗黙的にcharへの変換を許可できるかもしれません)。

関数内にあると想定し、コンソール(stdin)から読み取り、それに書き込む(stdout)。

編集:Char.IsUpper(s [j])はs [j]> 64 && s [j] <91より2バイト長く、Char.ToUpperは私のバージョンよりも長いです。


0

Haskell、222 207バイト

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

更新しました:

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"

使い方:

s=(+(-65)).ord

sx = xのASCII値-'A'のASCII値

f=(`divMod`32).s

f(sx)=(0、sx)は大文字、(1、(s x-32))は小文字

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

fでインデックス可能な文字の並列リスト(小文字-> 1->大文字、大文字-> 0->小文字)

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

英数字以外の文字を返し、そのs-valueが現在のクリスマスの文字と同じ場合(次の文字に移動する場合)文字を保持するか、そうでない場合は他の場合に変換して続行する

main=interact$k c

IO

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.