Diskuze: C# úprava řetězce
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Tvůrce
Zobrazeno 8 zpráv z 8.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Třída String obsahuje metody ToUpper, Replace. Zbytek bys měl zvládnout.
No nechce se mi to dělat přes pole znaků...
Jestli není nějaké úspornější řešení?
Nějak nechápu co je neúsporného na tom že zavoláš pár metod.
internal class Program
{
[STAThread]
private static void Main(string[] args)
{
var input = "Já-Ondra mám rád% římská(!!!) stavení. :-)";
var result = input.ToRetardedUpper();
var expected = "JAONDRAMAMRADRIMSKASTAVENI";
if (result != expected)
Debugger.Break();
}
}
public static class StringExtensions
{
public static string ToRetardedUpper(this string s)
{
return new string(s.Normalize(NormalizationForm.FormKD)
.Where(c => char.IsLetter(c))
.Select(c => char.ToUpper(c))
.ToArray());
}
}
TBH, nechce se mi už zkoumat jaký je rozdíl mezi compatibility a canonical decomposition, takže buď tam použiješ D a nebo KD.
Rozdíl je velice významný, ale musel bys použít speciální znaky, abys
ho rozpoznal.
V tomhle případě [převod na uppercase ASCII] chceš compatibility
decomposition, abys získal dekompozice ligatur a jiných speciálně
formátovaných znaků, takže FormKD je správně.
V kanonické dekompozici by některé znaky mohly být identifikovány
nekorektně kvůli formátování.
Přemýšlíš v podstatě správně ale nemá to efekt jaký si myslíš. Přemýšlíš pouze ve svém malém programátorském kontextu. Sice může existovat nějaká magiská metoda přímo v .NET FW UdelejMiPresneToCoChci a bude třeba na jeden řádek ale ta i ta .NET metoda tak jako tak musí vzít písmento po písmenku a udělat s tím co je potřeba.
Nechtěl jsem ti dávat hodové řešení, protože si myslím, že to nováčkům vypíná mozek a je to v jádru kontraproduktivní do budoucna. Ale na procházení znaku po znaku nic není. Ten počítač to musí tak jako tak udělat, jen ty to nevidíš. Jde jen o to abys to ty udělal optimálně.
Tak to mám hotové, dík cicobasket za ujištění, že není metoda UdelejMiPresneToCoChci()
static string RemoveDiacritics(string s)
{
s = s.Normalize(NormalizationForm.FormD);
string output = "";
for (int i = 0; i < s.Length; i++)
{
if (CharUnicodeInfo.GetUnicodeCategory(s[i]) != UnicodeCategory.NonSpacingMark)
output += s[i];
}
return output;
}
static string Modify(string s)
{
s = RemoveDiacritics(s);
s = s.ToUpper();
string allowed_chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
string output = "";
for (int i = 0; i < s.Length; i++)
if (allowed_chars.Contains(s[i]))
output += s[i];
return output;
}
Zobrazeno 8 zpráv z 8.