PowerShell, 154 , 152 , 99 , 86 bytes
Obrigado, @TimmyD, por me salvar 47 bytes (também guardei outros 6)
Obrigado ao @TessellatingHeckler por salvar 13 bytes adicionais.
Mais recentes:
param($a)-join($a[$a.length..0]|%{("$_".ToLower(),"$_".ToUpper())[$a[$i++]-in65..90]})
Original:
param($a);$x=0;(($a[-1..-$a.length])|%{$_=$_.tostring().tolower();if([regex]::matches($a,"[A-Z]").index-contains$x){$_.toupper()}else{$_};$x++})-join''
Formatação normal:
Mais recente (parece melhor como duas linhas na minha opinião):
param($a)
-join($a[$a.length..0] | %{("$_".ToLower(), "$_".ToUpper())[$a[$i++] -in 65..90]})
Explicação:
param($a)-join($a[$a.length..0]|%{("$_".ToLower(),"$_".ToUpper())[$a[$i++]-in65..90]})
param($a)
# Sets the first passed parameter to variable $a
-join( )
# Converts a char array to a string
$a[$a.length..0]
# Reverses $a as a char array
|%{ }
# Shorthand pipe to foreach loop
("$_".ToLower(),"$_".ToUpper())
# Creates an array of the looped char in lower and upper cases
[$a[$i++]-in65..90]
# Resolves to 1 if the current index of $a is upper, which would output "$_".ToUpper() which is index 1 of the previous array
Original:
param($a)
$x = 0
(($a[-1..-$a.length]) | %{
$_ = $_.tostring().tolower()
if([regex]::matches($a,"[A-Z]").index -contains $x){
$_.toupper()
}else{
$_
}
$x++
}
) -join ''
O primeiro pôster aqui foi motivado porque raramente vejo o PowerShell, mas com 154 152 bytes neste aqui ... posso ver o porquê!Todas as sugestões apreciadas.
Aprendi que devo mudar completamente minha maneira de pensar para jogar golfe no código e é divertido!