PowerShell, 154 , 152 , 99 , 86 octets
Merci @TimmyD de m'avoir sauvé 47 octets (j'en ai également économisé 6 supplémentaires)
Merci @TessellatingHeckler d'avoir enregistré 13 octets supplémentaires.
Dernier:
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''
Formatage normal:
Dernier (semble meilleur que deux lignes à mon avis):
param($a)
-join($a[$a.length..0] | %{("$_".ToLower(), "$_".ToUpper())[$a[$i++] -in 65..90]})
Explication:
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 ''
La première affiche ici, était motivée parce que je vois rarement PowerShell, mais à 154 152 octets sur celui-ci ... je peux voir pourquoi! Toutes suggestions appréciées.
J'ai appris que je dois changer complètement ma façon de penser au golf dans le code et son plaisir!