Vydělávej až 160.000 Kč měsíčně! Akreditované rekvalifikační kurzy s garancí práce od 0 Kč. Více informací.
Hledáme nové posily do ITnetwork týmu. Podívej se na volné pozice a přidej se do nejagilnější firmy na trhu - Více informací.
Avatar
Tomáš Hauser:7.2.2018 21:23

Ahoj,
poradí mi někdo, jak udělat, aby mi v tomhle kódu program převedl y0 na znaménko, které následně použije jako znak pro operaci, kterou má vykonat mezi x a y?
Díky

string x0, y0;
int x, y, z;
Console.WriteLine("Zadejte x + - / y.");
x0 =  Console.ReadLine();
x  =  Convert.ToInt32(x0.Split (' ') [0]);
y0 =  Convert.ToString(x0.Split(' ') [1]);
y  =  Convert.ToInt32(x0.Split (' ') [2]);
z  = x y0 y;
Console.WriteLine("{0} + {1} = {2}", x, y, z);
 
Odpovědět
7.2.2018 21:23
Avatar
Radovan Pelka:7.2.2018 21:38

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;
}
Nahoru Odpovědět
7.2.2018 21:38
Když nevíš tak koumej.
Avatar
Tomáš Hauser:7.2.2018 21:41

Díky, ale já rád dělám kódy co nejkratší, a tak by mě zajímalo, jestli to takhle jde.
Case samozřejmě znám a umím ho použít, ale kamarád dostal tenhle nápad a vrtá mi to v hlavě. :)

 
Nahoru Odpovědět
7.2.2018 21:41
Avatar
Jan Procházka:7.2.2018 21:52

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

Editováno 7.2.2018 21:54
 
Nahoru Odpovědět
7.2.2018 21:52
Avatar
Odpovídá na Jan Procházka
Tomáš Hauser:7.2.2018 22:01

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é.

 
Nahoru Odpovědět
7.2.2018 22:01
Avatar
Radovan Pelka:7.2.2018 22:22

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. :-)

Nahoru Odpovědět
7.2.2018 22:22
Když nevíš tak koumej.
Avatar
gcx11
Tvůrce
Avatar
Odpovídá na Tomáš Hauser
gcx11:7.2.2018 22:24

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.

 
Nahoru Odpovědět
7.2.2018 22:24
Avatar
Petr Šťastný
Tvůrce
Avatar
Odpovídá na Tomáš Hauser
Petr Šťastný:7.2.2018 22:55

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)

 
Nahoru Odpovědět
7.2.2018 22:55
Avatar
xpoproci
Člen
Avatar
xpoproci:7.2.2018 23:49

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]);
Nahoru Odpovědět
7.2.2018 23:49
Motto
Avatar
zelvicek
Člen
Avatar
Odpovídá na Tomáš Hauser
zelvicek:8.2.2018 15:29

Xpoproci už nabídl řešení podle zadání, ale dovolím si nabídnout taky jedno (byť je to kanón na vrabce).

https://github.com/…-API-Samples

Editováno 8.2.2018 15:31
 
Nahoru Odpovědět
8.2.2018 15:29
Avatar
zelvicek
Člen
Avatar
Odpovídá na Tomáš Hauser
zelvicek:9.2.2018 10:47

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.

Editováno 9.2.2018 10:48
 
Nahoru Odpovědět
9.2.2018 10:47
Děláme co je v našich silách, aby byly zdejší diskuze co nejkvalitnější. Proto do nich také mohou přispívat pouze registrovaní členové. Pro zapojení do diskuze se přihlas. Pokud ještě nemáš účet, zaregistruj se, je to zdarma.

Zobrazeno 11 zpráv z 11.