Miten on järkevintä tehdä yksinkertainen laskin joka laskee plus-, miinus-, kerto- ja jakolaskuja?
Olen saanut aikaiseksi sellaisen laskimen joka kyllä toimii mutta sekoaa jos siihen syöttää kirjaimia...
Nykyinen laskin on tehty do-while-rakenteella.
1-4 numeroilla valitaan laskutoimitus ja 0 lopettaa. Laskutoimitukset suoritetaan aliohjelmissa...
Laskin ongelmia
5
1004
Vastaukset
- pjotrrrrrr
Kaiketikkin nopein/yksinkertiaisin tapa lienee tehdä laskutoimitukset try-catch rakenteen sisällä. Ohjelman ei ainakaan pitäisi seota sitten.
Mutta siihen miten tommonen laskin on "järkevintä" tehdä, niin en ota kantaa :) Nykyistä toteutustapaa en kyllä oikein ymmärrä, mutta jos se toimii niin anna palaa xD - pjotrrrrr
Kaiketikkin nopein/yksinkertiaisin tapa lienee tehdä laskutoimitukset try-catch rakenteen sisällä. Ohjelman ei ainakaan pitäisi seota sitten.
Mutta siihen miten tommonen laskin on "järkevintä" tehdä, niin en ota kantaa :) Nykyistä toteutustapaa en kyllä oikein ymmärrä, mutta jos se toimii niin anna palaa xD - Metsäminnni
Onko kellään mitään esimerkkiä?
- tämän kaltaista
Nopeesti miettien näin. Koodi ei suoriltaan toimi et sinne joutuu lisään omaa tauhkaa.
käyttäjä siis on valinnut minkä laskutoimituksen haluaa:
while(valid){
//kysytään lukut
try{
double d = Double.parseDouble(luku);
double p = Double.parseDouble(luku2);
valid = false;
}
catch(ParseException ex){}
}
System.out.println("tulos on:" c);
- ma_vaan__
Joskus väsäsin rpn-laskimen, tosin se laskee vaan miinus ja plus laskuja, mutta lisäämällä siihen saa helposti jako ja kerto laskut ja toi on tehty c-kielellä, mutta tässä ainaki pääohjelmasta esimerkki (aika huonosti rivittyy :)
//Laskin käyttää RPN notaatiota (Reverse Polish //Notation) eli se on ns. //pinolaskin.Pinolaskimella laskettaessa annetaan //ensin laskettavat luvut ja sitten vasta //laskutoimitus.
int main(void)
{
Tintstack stack;
Tboolean succeeded;
int item, pop_item = 0, i, sum = 0;
int luku = 0;
initialize_int_stack(&stack);
printf("RPN-laskin. Ohjelmalle annetaan yksinumeroisia kokonaislukuja");
printf("\nja operaatioita , - = ja L. Operaatio = tulostaa pinon");
printf("\npaallimaisen alkion. Operaatio L lopettaa ohjelman.\n>");
while((item = getchar()) != 'L') //getchar ottaa vastaan merkin, jos merkki L niin while silmukka päättyy
{
fflush(stdin);
if(item == ' ')
{
sum = 0;
succeeded = pop_int(&stack, &pop_item);
if(succeeded == 0) //tarkistetaan onko pinossa operandia
{
printf("Pinossa ei operandia %d\n", succeeded);
}
else
{
sum = pop_item sum;
succeeded = pop_int(&stack, &pop_item);
if(succeeded == 0) //tarkistetaan onko pinossa operandia
{
printf("Pinossa ei operandia\n");
}
else
{
sum = pop_item sum;
if(push_int(&stack, sum) == 0) //laitetaan summa pinoon päällimmäiseksi
{
printf("/nStack is full"); //push_int() palauttaa 0 jos pino täynnä ja 1 jos pino ei ole täynnä
}
else
{
//printf("Summa tallennettiin pinoon\n");
}
}
}
}
else if(item == '-')
{
sum = 0;
succeeded = pop_int(&stack, &pop_item);
if(succeeded == 0) //tarkistetaan onko pinossa operandia
{
printf("Pinossa ei operandia %d\n", succeeded);
}
else
{
sum = pop_item-sum; //erotus
succeeded = pop_int(&stack, &pop_item);
if(succeeded == 0) //tarkistetaan onko pinossa operandia
{
printf("Pinossa ei operandia\n");
}
else
{
sum = pop_item-sum; //erotus
if(push_int(&stack, sum) == 0) //Tallennetaan erotus pinoon päällimmäiseksi
{
printf("/nStack is full"); //push_int() palauttaa 0 jos pino täynnä ja 1 jos pino ei ole täynnä
}
else
{
//printf("Erotus tallennettiin pinoon\n");
}
}
}
}
else if(item == '=')
{
succeeded = pop_int(&stack, &pop_item);
if(succeeded == 0) //tarkistetaan onko pinossa operandia
{
printf("Pinossa ei operandia\n");
}
else
{
printf("\t \t tulos %d\n", pop_item);
}
if(push_int(&stack, pop_item) == 0) //laitetaan takasi pinoon päällimmäiseksi
{
printf("/nStack is full"); //push_int() palauttaa 0 jos pino täynnä ja 1 jos pino ei ole täynnä
}
}
else if(isdigit(item)) //onko numero
{
if(push_int(&stack, item - '0') == 0) //laitetaan käyttäjän syöttämä merkki pinoon päällimmäiseksi, täytyy vähentää '0' koska ascii
{
printf("/nStack is full"); //push_int() palauttaa 0 jos pino täynnä ja 1 jos pino ei ole täynnä
}
else
{
//printf("Merkki tallennettiin pinoon\n");
}
}
else
{
printf("Et antanut oikein\n");
}
printf(">");
}
print_int_stack (&stack);
system("PAUSE");
return 0;
}
Ketjusta on poistettu 0 sääntöjenvastaista viestiä.
Luetuimmat keskustelut
Kuinkahan paljon taas itken tulevina öinä
meitä ja sitä, miten kaikki meni. Miten rikki se repi sydäntä ja jäljelle jäi pysyvä suru. En vain pääse siitä, ei hetke759649Kitaristi Esa Pulliainen laihtunut
Tietääkö kukaan minkä takia Esa Pulliainen on laihtunut lyhyessä ajassa ainakin 60 kiloa. Esa Pulliainen laihtunut 😳1385112Pienimäki ei anna haastatteluja
medialle Ähtärin kunnan velka sotkuista, kertovat luotettavat lähteet.173928- 373731
- 223130
- 881951
En tiedä mitä ajatella
Petaatko perjantaille jotain. Ei meidän kannata minun sydän on viety. Se joka sen vei ei ole mieheni, etkä se ole sinä.361772Hyviä vinkkejä täällä
Eli kaivattua vain kädestä kiinni ja jos vastustelee niin sanoo, että hei beibi beibi nyt mennään vaan. Näin he elivät e171637voitaisiinko unohtaa se sotku?
Olisiko mahdollista aloittaa puhtaalta pöydältä vielä? Ikävä sua ****161609Naisten ulkonäkö, jos miehiä ei olisi?
Mä meinasin ensiksi, että en aloittaisi tätä keskustelua, ainan nyt, mutta huomasin tossa toisessa ketjussa, että tämä s2451599