Facey McFaceface

47

Alguém se lembra de Boaty ?

Você poderia fazer qualquer palavra antiga, certo?

  • Escreva uma função para transformar uma string em Somethingy McSomethingface.
  • Ele deve aceitar uma string como entrada. Ignore o caso da entrada.
  • Se a palavra terminar em 'y', sua função não deve adicionar um 'y' adicional à primeira instância, mas deve removê-la na segunda instância.
  • Se a palavra terminar em 'ey', ela não deverá ter um 'y' adicional adicionado na primeira instância, mas deverá remover as duas na segunda instância.
  • A saída deve ter apenas letras maiúsculas no primeiro caractere, o 'M' de 'Mc' e o primeiro caractere após 'Mc'.
  • ele só precisa trabalhar com cadeias de caracteres de 3 ou mais caracteres.

Exemplos:

boat                  =>  Boaty McBoatface
Face                  =>  Facey McFaceface
DOG                   =>  Dogy McDogface
Family                =>  Family McFamilface
Lady                  =>  Lady McLadface
Donkey                =>  Donkey McDonkface
Player                =>  Playery McPlayerface
yyy                   =>  Yyy McYyface
DJ Grand Master Flash =>  Dj grand master flashy McDj grand master flashface
AJFaraday
fonte
E quanto aos espaços na string, nós os deixamos intactos? Exemplos: ' y'e' '
touch my body
2
Vou implementar uma sugestão do @Arnauld e torná-la no mínimo três caracteres. Trate os espaços em branco como outra letra.
AJFaraday
Podemos assumir que a entrada conterá apenas letras maiúsculas e minúsculas?
Kevin Cruijssen 28/03
@KevinCruijssen Eu não coloquei nenhuma letra não nos casos de teste, então eles não estão preocupados.
AJFaraday

Respostas:

7

Stax , 26 bytes

ëO╛εh╕⌠î&!}∞┌C^U╟«äδ◙Bg⌠└¿

Execute e depure

^           convert input to upper case                     "FACE"
B~          chop first character and push it back to input  70 "ACE"
v+          lowercase and concatenate                       "Face"
c'yb        copy, push "y", then copy both                  "Face" "Face" "y" "Face" "y"
:]          string ends with?                               "Face" "Face" "y" 0
T           trim this many character                        "Face" "Face" "y"
+           concatenate                                     "Face" "Facey"
p           output with no newline                          "Face"
"e?y$"z     push some strings                               "Face" "e?y$" ""
" Mc`Rface  execute string template; `R means regex replace " Mc Faceface"
            result is printed because string is unterminated

Execute este

recursivo
fonte
15

V , 27 28 30 bytes

Vu~Ùóe¿y$
Hóy$
ÁyJaMc<Esc>Aface

Experimente online!

<Esc> representa 0x1b

  • Golpeou dois bytes depois de saber que não precisávamos oferecer suporte a entradas com menos de 3 caracteres.

  • 1 byte economizado graças a @DJMcMayhem, trabalhando na segunda linha antes da primeira, removendo assim o G

A entrada está no buffer. O programa começa convertendo tudo para minúsculas

Vseleciona a linha e a uminúscula

~ alterna entre maiúsculas e minúsculas o primeiro caractere (convertendo-o para maiúsculas)

e Ùduplica esta linha acima, deixando o cursor na linha inferior

óe substitui e¿y$, forma compactada de e\?y$(opcional ee a yno final da linha), por nada (acontece na segunda linha)

H vai para a primeira linha

ósubstitui y$( yno final da linha) por nada na primeira linha

Áanexa ya ao final da primeira linha

J e une a última linha à primeira com um espaço no meio e o cursor é movido para esse espaço

aacrescenta Mc( <Esc>retorna ao modo normal)

Afinalmente, acrescenta faceno final da linha

Kritixi Lithos
fonte
27 bytes: Experimente online!
DJMcMayhem
13

Python, 144 bytes

def f(s):
 s=s[0].upper()+s[1:].lower()
 y=lambda s:s[:-1]if s[-1]=='y'else s
 t=y(s)
 u=s[:-2]if s[-2:]=='ey'else y(s)
 return t+'y Mc%sface'%u

Experimente online aqui

toque meu corpo
fonte
2
minha primeira tentativa de golfe com código ...
touch my body
3
bem-vindo ao PPCG! sugiro adicionar um link para Experimente Online! para verificação da correção?
Giuseppe
1
f("Face")não está de acordo com os casos de teste atuais ( TIO ).
Jonathan Frech 27/03
Postagem editada para correção, também adicionou um Experimente Online! link
touch my body
1
97 bytes.
totallyhuman 27/03
12

Excel, 204 144 137 165 bytes

=SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(REPT(REPLACE(LOWER(A1),1,1,UPPER(LEFT(A1)))&"~",2),"~","y Mc",1),"yy ","y "),"ey~","~"),"y~","~"),"~","face")

De dentro para fora:

REPLACE(LOWER(A1),1,1,UPPER(LEFT(A1)))      Replaces PROPER to handle space-delimited cases
REPT(%&"~",2)                   Duplicate.                    Donkey~Donkey~
SUBSTITUTE(%,"~","y Mc",1)      Replace first ~.              Donkeyy McDonkey~
SUBSTITUTE(%,"yy ","y ")        Handle words ending in 'y'.   Donkey McDonkey~
SUBSTITUTE(%,"ey~","~")         Handle words ending in 'ey'   Donkey McDonk~
SUBSTITUTE(%,"y~","~")          Handle words ending in 'y'    Donkey McDonk~
SUBSTITUTE(%,"~","face")        Adding face.                  Donkey McDonkface

Resposta antiga, criando todos os bits separadamente e concatenando (176 bytes). Não processa casos delimitados por espaço corretamente.

=PROPER(A1)&IF(LOWER(RIGHT(A1,1))="y",,"y")&" Mc"&IF(LOWER(RIGHT(A1,2))="ey",LEFT(PROPER(A1),LEN(A1)-2),IF(LOWER(RIGHT(A1,1))="y",LEFT(PROPER(A1),LEN(A1)-1),PROPER(A1)))&"face"
Wernisch
fonte
Infelizmente, devido ao requisito de lidar com casos delimitados por espaço, PROPER(A1)é inválido (consulte o DJ Grand Master Flashcaso de entrada), a melhor substituição que eu encontrei enquanto trabalhava na minha solução VBA foi LEFT(UPPER(A1))&MID(LOWER(A1),2,LEN(A1))- informe-me se você acabar jogando isso.
Taylor Scott
1
Obrigado @TaylorScott. Encontrado 'REPLACE (LOWER (A1), 1,1, UPPER (ESQUERDA (A1))) `, que é 2 bytes mais curto.
Wernisch 12/04
9

C # (.NET Core) , 122 108 139 175 180 179 154 bytes

Muito obrigado, lee!

s=>((s.EndsWith("y")?s:s+"y")+" Mc"+(s+"$").Replace("ey$","")+"face").Replace(s,s.ToUpper()[0]+s.Substring(1).ToLower()).Replace("y$","").Replace("$","");

Experimente online!

C # (.NET Core, com LINQ), 152 bytes

s=>((s.Last()=='y'?s:s+"y")+" Mc"+(s+"$").Replace("ey$","")+"face").Replace(s,s.ToUpper()[0]+s.Substring(1).ToLower()).Replace("y$","").Replace("$","");

Experimente online!

Anderson Pimentel
fonte
3
Bem vindo ao site! :)
DJMcMayhem
7

Ruby , 61 49 bytes

->s{s.capitalize=~/(e)?y$|$/;"#$`#$1y Mc#$`face"}

Experimente online!

Guardou 12 bytes doces graças a @MartinEnder:

iamnotmaynard
fonte
1
Usar o regex da minha resposta Retina e usar um pouco mais a interpolação de string reduz esse número para 49: tio.run/##DcxBCsIwEEDRqwxJBF3Y4lpSN0U3igcQwTQmGFptMVNkTOLVY3bvb/
Martin Ender
@ MartinEnder Uau, isso é bastante diferente. Acho que não vi interpolação de strings sem colchetes. Aceito se você não quiser usá-lo para sua própria resposta Ruby.
Iamnotmaynard 28/0318
Não, está tudo bem, eu não teria inventado =~e construído toda a string em vez de usar sub. A interpolação de string pode ser usada sem colchetes se a variável for uma variável global, de instância ou classe.
Martin Ender
Você pode obter isso para 44 + 1 bytes usando o -psinalizador e usando sub: tio.run/…
Jordânia
7

Python 3 , 80 bytes

Leitor ávido de muito tempo, finalmente minha primeira submissão!

lambda y:re.sub("([\w ]+?)((e)?y)?$",r"\1\3y Mc\1face",y.capitalize())
import re

Experimente online

eteno
fonte
1
Bem-vindo ao PPCG e muito bom primeiro post!
Zachary
5

Python 2 , 88 92 bytes

lambda s:(s+'y'*-~-(s[-1]in'yY')).title()+' Mc'+re.sub('e?y$','',s.title())+'face'
import re

Experimente online!

Chas Brown
fonte
3
Falha com 'FamilY'
Dead Possum
@ Gambá morto: corrigido. Thks!
quer
5

Java 8, 121 112 107 106 bytes

s->(s=(char)(s.charAt(0)&95)+s.toLowerCase().substring(1)).split("y$")[0]+"y Mc"+s.split("e?y$")[0]+"face"

-1 byte graças a @ OliverGrégoire .

Explicação:

Experimente online.

s->                         // Method with String as both parameter and return-type
  (s=                       //  Replace and return the input with:
     (char)(s.charAt(0)&95) //   The first character of the input as Uppercase
     +s.toLowerCase().substring(1))
                            //   + the rest as lowercase
  .split("y$")[0]           //  Remove single trailing "y" (if present)
  +"y Mc"                   //  Appended with "y Mc"
  +s.split("e?y$")[0]       //  Appended with the modified input, with "y" or "ey" removed
  +"face"                   //  Appended with "face"
Kevin Cruijssen
fonte
E se o primeiro caractere não for alfabético? Ou talvez nós podemos começar uma regra adicional sobre isso ..
streetster
1
@streetster Acabei de perguntar ao OP, e parece que a entrada contém apenas letras maiúsculas e / ou minúsculas.
Kevin Cruijssen 28/03
1
~32-> 95por 1 byte salvo
Olivier Grégoire
@ OlivierGrégoire Eu realmente preciso começar a aprender um pouco mais sobre operações bit a bit ..>.>
Kevin Cruijssen
4

JavaScript, 103 96 94 bytes

Bastante ingênuo primeiro passo nisso.

s=>(g=r=>s[0].toUpperCase()+s.slice(1).toLowerCase().split(r)[0])(/y$/)+`y Mc${g(/e?y$/)}face`

Experimente online

Shaggy
fonte
s =>${s=s[0].toUpperCase()+s.slice(1).toLowerCase().replace(/y$/,``)}y Mc${s.replace(/e?y$/,``)}face
Benjamin Gruenbaum 27/03
Um a menos: s =>${s=s[0].toUpperCase()+s.slice(1).toLowerCase().replace(/y$/,'')}y Mc${s.replace(/e$/,``)}face
Benjamin Gruenbaum 27/03
Obrigado, @BenjaminGruenbaum, mas o primeiro falha Donkeye o segundo a Face.
Salsicha
A remarcação está arruinando o código: gist.github.com/benjamingr/8fec077b5436846cc9c52be353238037
Benjamin Gruenbaum
@ Shaggy eu consegui reduzir a função g em alguns caracteres :). você pode procurar na minha solução #
317 DanielIndie
3

vim, 35 34 bytes

Vu~Yp:s/ey$
:%s/y$
kgJiy Mc<ESC>Aface<ESC>

<ESC> é 0x1b

Ungolfed

Vu~                      # Caseify McCaseface
Yp                       # dup line
:s/ey$ 
:%s/y$                   # Get the suffixes right
kgJiy Mc<ESC>Aface<ESC>  # Join lines and add the extra chars

Experimente online!

Guardado 1 byte graças a DJMcMayhem

Raio
fonte
1
Você pode fazer em Yvez deyy
DJMcMayhem
3

Perl 5 -p , 47 39 bytes

Salvei 6 bytes com as sugestões de @ OlegV.Volkov, 1 com @ mwellnhof e 1 sozinho

$_=lc^$";$_=s/y?$/y Mc/r.s/e?y$//r.face

Experimente online!

Xcali
fonte
Você pode se livrar de ucfirst:$_=lc^$";
Oleg V. Volkov
$_=s/y$//r."y Mc".s/e?y$//r.faceé um byte mais curto.
Nwellnhof 28/03/19
1
/y$|$/->/y?$/
Oleg V.Volkov
Duh. Eu deveria ter percebido isso.
Xcali
3

C ++ 14 (g ++), 181 171 148 147 134 bytes

[](auto s){s[0]&=95;int i=1,b;for(;s[i];)s[i++]|=32;b=s[--i]-'y';return s+(b?"y":"")+" Mc"+(b?s:s.substr(0,s[i-1]-'e'?i:i-1))+"face";}

Observe que o clang não compila isso.

Crédito para Kevin Cruijssen e Olivier Grégoire pelo &95truque.

Agradecimentos a Chris por jogar 11 bytes.

Experimente online aqui .

Versão não destruída:

[] (auto s) { // lambda taking an std::string as argument and returning an std::string
    s[0] &= 95; // convert the first character to upper case
    int i = 1, // for iterating over the string
    b; // we'll need this later
    for(; s[i] ;) // iterate over the rest of the string
        s[i++] |= 32; // converting it to lower case
    // i is now s.length()
    b = s[--i] - 'y'; // whether the last character is not a 'y'
    // i is now s.length()-1
    return s + (b ? "y" : "") // append 'y' if not already present
    + " Mc"
    + (b ? s : s.substr(0, s[i-1] - 'e' ? i : i-1)) // remove one, two, or zero chars from the end depending on b and whether the second to last character is 'e'
    + "face";
}
OOBalance
fonte
Não conheço C ++ tão bem, mas você pode jogar com 9 bytes: experimente online 172 bytes. Resumo das alterações: s[0]=s[0]&~32;para s[0]&=~32;; s[i++]=s[i]|32;para s[i++]|=32; e int i=1,n=s.length()-1,b;então você só precisa de 1 int.
Kevin Cruijssen 28/03/19
Ah, e mais um byte removendo o espaço em#include<string>
Kevin Cruijssen 28/03
@KevinCruijssen obrigado por capturar isso! Eu editei.
OOBalance
Você pode salvar 11 bytes não definindo ne apenas usando o valor de iapós o loop while. Experimente online!
30518 Chris
@ Chris Obrigado! Eu consegui raspar mais 2 bytes.
OOBalance
2

V , 38 36 32 bytes

-5 bytes graças ao @Cows quack

Vu~hy$ó[^y]$/&y
A Mc<esc>póe¿y$
Aface

<esc>é um caractere de escape literal e [^é codificado como\x84

Experimente online!

Herman L
fonte
gu$pode se tornarVu
Kritixi Lithos 27/03
2
Como [^é um atalho de regex (veja aqui ), você pode usar 0x84 em vez de [^salvar um byte. Da mesma forma, \?pode ser simplificado <M-?>para salvar outro byte. E $a=>A
Kritixi Lithos 27/03
2

Python 3 , 117 114 bytes

-3 bytes graças ao Dead Possum

def f(s):s=s.title();return s+'y'*(s[-1]!='y')+' Mc'+([s,s[:-1],0,s[:-2]][(s[-1]=='y')+((s[-2:]=='ey')*2)])+'face'

Experimente online!

Dat
fonte
O terceiro elemento da lista [s,s[:-1],'',s[:-2]pode ser alterado para 0para salvar 1 byte.
Gambá morto
In 'y'*1 *1não é necessário. Mais 2 bytes
Dead Possum
Mudar de Python 3 para Python 2 e substituí-lo returnpor print1 byte menor.
Kevin Cruijssen 28/03
2

JavaScript (Node.js) , 87 bytes

  • graças a @Shaggy por 5 reduzindo 5 bytes
s=>(g=r=>Buffer(s.replace(r,"")).map((x,i)=>i?x|32:x&~32))(/y$/)+`y Mc${g(/e?y$/)}face`

Experimente online!

DanielIndie
fonte
2
Você não precisa nomear funções não recursivas.
Dennis
1
Bem feito. Eu nunca penso em usar Buffer, vou ter que tentar lembrá-lo para desafios futuros. Reduzimos para 87 bytes para você.
Shaggy
2

K4 , 74 69 68 bytes

Solução:

{$[r;x;x,"y"]," Mc",_[r:0&1-2/:"ye"=2#|x;x:@[_x;0;.q.upper]],"face"}

Exemplos:

q)k)f:{$[r;x;x,"y"]," Mc",_[r:0&1-2/:"ye"=2#|x;x:@[_x;0;.q.upper]],"face"}
q)f each ("boat";"Face";"DOG";"Family";"Lady";"Donkey";"Player")
"Boaty McBoatface"
"Facey McFaceface"
"Dogy McDogface"
"Family McFamilface"
"Lady McLadface"
"Donkey McDonkface"
"Playery McPlayerface"

Explicação:

Descobrir se os últimos caracteres são iguais a "ey", converter resultado em base-2 para que possamos ignorar as palavras que terminam "e?". Índice em uma lista de números de caracteres para aparar.

Consegui remover 5 bytes do meu código para determinar se os dois últimos caracteres, "ey"mas lutando para melhorá-lo ...

{$[r;x;x,"y"]," Mc",_[r:0&1-2/:"ye"=2#|x;x:@[_x;0;.q.upper]],"face"} / the solution
{                                                                  } / lambda function
                                                            ,"face"  / join with "face"
                    _[                  ;                  ]         / cut function
                                           @[_x; ;        ]          / apply (@) to lowercased input
                                                0                    / at index 0
                                                  .q.upper           / uppercase function
                                         x:                          / save back into x
                                      |x                             / reverse x
                                    2#                               / take first two chars of x
                               "ye"=                                 / equal to "ye"?
                             2/:                                     / convert to base 2
                           1-                                        / subtract from 1
                         0&                                          / and with 0 (take min)
                       r:                                            / save as r
             ," Mc",                                                 / join with " Mc"
 $[r;x;x,"y"]                                                        / join with x (add "y" if required)

Bônus:

Porta de 67 bytes em K (oK) :

{$[r;x;x,"y"]," Mc",((r:0&1-2/"ye"=2#|x)_x:@[_x;0;`c$-32+]),"face"}

Experimente online!

rua
fonte
1
Qual o sentido do K4 se sua porta oK o derrotar?
Zachary
Eu não pensei que funcionaria, e a porta não funcionará se o primeiro caractere não estiver em ordem alfabética, pois subtraio cegamente 32 do valor ASCII - não há nenhum "superior" embutido.
streetster
2

Ruby , 69 bytes

->s{"#{(s.capitalize!||s)[-1]==?y?s:s+?y} Mc#{s.gsub /e?y$/,""}face"}

Explicação:

->s{                                                                } # lambda 
    "#{                                 } Mc#{                }face" # string interpolation
       (s.capitalize!||s) # returns string capitalized or nil, in that case just use the original string
                         [-1]==?y # if the last character == character literal for y
                                 ?s:s+?y # then s, else s + "y"
                                              s.gsub /e?y$/,"" # global substitute
                                                               # remove "ey" from end

Experimente online!

dkudriavtsev
fonte
Você pode adicionar um link TIO? Não conheço Ruby, mas s.capitalizesubstitui o anterior s? Se não, faz /e?y$/lidar com um caso de teste que termina em Y, EYou Eycorretamente?
Kevin Cruijssen 28/03
1
@KevinCruijssen s.capitalizevs s.capitalize!(funções diferentes). s.capitalize!derruba a versão antiga.
dkudriavtsev
@KevinCruijssen Adicionei um link TIO.
dkudriavtsev 28/03
@KevinCruijssen Também acrescentou uma explicação
dkudriavtsev 28/03
Ah ok, obrigado pela explicação e pelas informações sobre s.capitalize!. Nunca programado no Ruby, mas adicionar uma marca de explicação para substituir o valor anterior é muito legal. +1 de mim.
Kevin Cruijssen 29/03
2

Jstx , 27 bytes

h</►yT↓►y/◙♂ Mc♀/◄eyg►yg/íå

Explicação

      # Command line args are automatically loaded onto the stack
h     # Title case the top of the stack
<     # Duplicate the top value on the stack twice
/     # Print the top value on the stack
►y    # Load 'y' onto the stack
T     # Returns true if the 2nd element on the stack ends with the top
↓     # Execute block if the top of the stack is false
  ►y  # Load 'y' onto the stack
  /   # Print the top value on the stack
◙     # End the conditional block
♂ Mc♀ # Load ' Mc' onto the stack
/     # Print the top value on the stack
◄ey   # Load 'ey' onto the stack
g     # Delete the top of the stack from the end of the 2nd element on the stack if it exists
►y    # Load 'y' onto the stack
g     # Delete the top of the stack from the end of the 2nd element on the stack if it exists
/     # Print the top of the stack
íå    # Load 'face' onto the stack
      # Print with newline is implied as the program exits

Experimente online!

Quantum64
fonte
Eu não vi esse idioma antes. Parece interessante. Existe documentação?
recursivo
1
@ recursive Aqui está uma documentação.
precisa saber é o seguinte
Uau, isso é realmente impressionante. Especialmente por tão pouco tempo de desenvolvimento. Estou animado para ver onde isso vai.
recursivo
2

Vermelho , 143 142 bytes

func[s][s: lowercase s s/1: uppercase s/1
w: copy s if"y"<> last s[append w"y"]rejoin[w" Mc"parse s[collect keep to[opt["y"|"ey"]end]]"face"]]

Experimente online!

Ungolfed:

f: func[s][
   s: lowercase s                      ; make the entire string lowercase
   s/1: uppercase s/1                  ; raise only its first symbol to uppercase 
   w: copy s                           ; save a copy of it to w
   if "y" <> last s[append w "y"]     ; append 'y' to w if it doesn't have one at its end
   rejoin[w                            ; assemble the result by joining:
          " Mc"
          ; keep the string until "y", "ey" or its end
          parse s[collect keep to [opt ["y" | "ey"] end]]
          "face"
    ]
]
Galen Ivanov
fonte
2

PHP: 132

<?php function f($s){$s=ucfirst(strtolower($s));return $s.(substr($s,-1)=='y'?'':'y').' Mc'.preg_replace('/(ey|y)$/','',$s).'face';}

Explicação:

<?php

function f($s)
{
    // Take the string, make it all lowercase, then make the first character uppercase
    $s = ucfirst(strtolower($s));

    // Return the string, followed by a 'y' if not already at the end, then ' Mc'
    // and the string again (this time, removing 'y' or 'ey' at the end), then
    // finally tacking on 'face'.
    return $s
        . (substr($s, -1) == 'y' ? '' : 'y')
        . ' Mc'
        . preg_replace('/(ey|y)$/', '', $s)
        . 'face';
}
Chris Forrence
fonte
2

Geléia , 77 75 74 73 bytes

2ḶNṫ@€⁼"“y“ey”S
ØA;"ØaF
¢y⁸µ¢Uyµ1¦
Çṫ0n”yẋ@”y;@Ç;“ Mc”
⁸JU>ÑTị3Ŀ;@Ç;“face

Experimente online!

Todas as sugestões de golfe são bem-vindas (e desejadas)!

Zacharý
fonte
2

Pyth, 36. 34 bytes

++Jrz4*\yqJK:J"e?y$"k+" Mc"+K"face

Experimente online!

Explicação:

++Jrz4*\yqJK:J"(e)?y$"k+" Mc"+K"face

  Jrz4                                  Set J to the titlecase of z (input)
           K:J"e?y$"k                   Set K to (replace all matches of the regex e?y$ in J with k (empty string))
         qJ                             Compare if equal to J
      *\y                               Multiply by "y" (if True, aka if no matches, this gives "y", else it gives "")
 +                                      Concatenate (with J)
                             +K"face    Concatenate K with "face"
                       +" Mc"           Concatenate " Mc" with that
+                                       Concatenate
RK.
fonte
Infelizmente, isso não funciona, pois o último caso de teste falha.
Zacharý 30/03/19
Alterne rz3para rz4que isso funcione corretamente no último caso de teste.
hakr14
Opa, eu vou consertar isso: P
RK.
2

Elixir , 112 110 107 106 bytes

agora tão curto quanto java

fn x->x=String.capitalize x;"#{x<>if x=~~r/y$/,do: "",else: "y"} Mc#{String.replace x,~r/e?y$/,""}face"end

Experimente online!

Explicação:

x=String.capitalize x

Obtém xo primeiro caractere em maiúsculas e todos os outros em minúsculas.

#{ code }

Avalie o código e insira-o na string.

#{x<>if x=~ ~r/y$/, do: "", else: "y"}

Concatena x com yse não termina com y(ou seja, não corresponde à regex y$).

#{String.replace x, ~r/e?y$/, "")}

Remove à direita eye à direita y.

Okx
fonte
1

PHP , 45 46 bytes

<?=($s=ucfirst(fgets(STDIN)))."y Mc{$s}face";

Experimente online!

Berry M.
fonte
Falha de duas maneiras diferentes na entrada boAty. (Tampões incorretos, 'y' não removido).
Oleg V. Volkov
1

Pyth, 60 59 bytes SBCS

K"ey"Jrz4Iq>2JK=<2J=kK.?=k\yIqeJk=<1J))%." s÷   WZÞàQ"[JkJ

Suíte de teste

Eles não são exibidos aqui, mas três bytes, \x9c, \x82, e \x8cestão na corda embalado entre se ÷. Fique tranqüilo, o link os inclui.

Tradução Python 3:
K="ey"
J=input().capitalize()
if J[-2:]==K:
    J=J[:-2]
    k=K
else:
    k="y"
    if J[-1]==k:
        J=J[:-1]
print("{}{} Mc{}face".format(J,k,J))
hakr14
fonte