Diskuze: Jednoduchá kalkulačka
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Člen
Zobrazeno 11 zpráv z 11.
//= 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.
Ahoj,
myslím, že když použiješ tohle tak to nemusíš nijak víc řešit jen jako výsledek bych nedělal int ale double. Přece víš, že int je jen celé číslo a třeba u dělění by to bylo asi nic moc.
switch (y0)
{
case "+":
z = x + y;
break;
case "-":
z = x - y;
break;
case "*":
z = x * y;
break;
case "/":
z = x / y;
break;
}
Radovan má pravdu.
Navíc dle tvého kódu, pokud zadáš "5 - 2" tak by ti to vrátilo "5 + 2 = 3", což je pro kalkulačku dost špatně.
Pro sčítání bys mohl pomocí if u nastavit pro rozdíl zápornou hodnotu y a pak by to vypisovalo "5 + -2 = 3", což už správně je, ale vypadá to divně...
A převést proměnnou na operaci nelze. V okamžiku kompilace totiž kompilátor neví jaký je obsah proměnné a tudíž neví na jaký příkaz ji má převést.
Další důvod, proč to nedělat, i kdyby to šlo, tak co by udělal vstup
"5 format%32C: 2"? spustil by příkaz format C:?
Příklad z PHP a SQL: XKCD
No jasně, tak to samý by bylo do těch uvozovek - prostě nějak převést proměnnou tak, aby ji program bral jako psaný text. Prostě když dám y0, tak aby tam program viděl to + nebo to - místo té proměnné.
Díky Jane,
a pro Toma, odpověď je již jasná a nemá cenu to nijak dále řešit. Nevím jak moc si v C# pokročilý ale určitě jsou mnohem zajímavější a důležitější věci.
Ahoj, ty sice píšeš program jako prostý text, ale počítač ho tak nevykonává.
Zjednodušeně:
Každá operace v programu (přiřazení do proměnné, porovnání sčítání,
odčítání, násobení...) se zapisuje jiným kódem pro počítač. Ale když
ten program překládáš do spustitelného souboru, tak překladač nemůže
vědět, co ty tam za běhu zadáš, proto nedokáže určit, co za operaci má
vygenerovat.
Jestli ti jde o jednoduchou kalkulačku, udělej to přes switch, takhle jak myslíš to jen tak udělat nepůjde (kdybys to vážně chtěl takhle dělat, což silně nedoporučuji, najdi si "c# eval string as code"). Kdybys chtěl vytvořit pokročilejší kalkulačku (neomezeně dlouhé výrazy, závorky, násobení, dělení, sčítání, odčítání, mocniny, odmocniny (v podstatě vše co si vymyslíš), podívej se na postfix notaci)
ak to chceš mať krátke tak sa to dá aj takto. ale ošetriť vstupy aby to bol matematický výraz až tak jednoduché nebude.
var res = new DataTable().Compute(Console.ReadLine(), "");
btw v tom tvojom kóde, hoď si ten split do jednej premennej, lebo voláš zbytočne 3x to isté.
var input = (Console.ReadLine()).Split(' ');
x = Convert.ToInt32(input[0]);
y0 = Convert.ToString(input[1]);
y = Convert.ToInt32(input[2]);
Xpoproci už nabídl řešení podle zadání, ale dovolím si nabídnout taky jedno (byť je to kanón na vrabce).
A ještě by mohlo přicházet v úvahu něco takového:
Dictionary<string, Func<int, int, int>> opers = new Dictionary<string, Func<int, int, int>>
{
{ "+", (xp,yp)=>xp+yp },
{ "-", (xp,yp)=>xp-yp },
{ "*", (xp,yp)=>xp*yp },
{ "/", (xp,yp)=>xp/yp }
};
string x0, y0;
int x, y, z;
string[] parts = x0.Split(' ');
x=Convert.ToInt32(parts[0]);
y0=Convert.ToString(parts[1]);
y=Convert.ToInt32(parts[2]);
z=opers[y0](x, y);
I když v celém tom zadání nevidím smysl.
Zobrazeno 11 zpráv z 11.