Funktionenverzweigung < C/C++ < Programmiersprachen < Praxis < Informatik < Vorhilfe
|
Status: |
(Frage) beantwortet | Datum: | 10:44 Mi 28.04.2010 | Autor: | max_e |
hallo zusammen,
nun, ich habe folgendes problem ich, stelle eine einfaches rechenprogramm
auf, dass mir +-/* ausrechnen. Nun will ich es mit funktionen verknüpfen
ok geht soweit gut. Bis auf den Fall mit dem ergebnis, ich will(dh. ich muss)
zusätzlich eine funktion aufstellen die im main abgearebeitet wird und mir letzenende das ergebnis zuweist... nun mein versuch ging daneben ich habe eine eigene funktion für ergebnis aufgestellt bekomme dann jedoch eine sehr seltsames ergebnis heraus....
irgendwo liegt der logikfehler-kann mir da einer helfen??
#include <iostream>
using namespace std;
void main (){
double zahl1,zahl2,ergebnis;
double e;
double ergebnisausgabe(double e);
double Adi(double zahl1, double zahl2),Supi(double zahl1, double zahl2),
Multi(double zahl1,double zahl2),Divis(double zahl1, double zahl2); //deklaration
char rechenzeichen;
cout<<"Eingabe der Rechenaufgabe:";
cin >> zahl1 >> rechenzeichen >> zahl2;
switch(rechenzeichen)
{
case '+' : ergebnis=Adi(zahl1,zahl2);break; //Anweisung
case '-' : ergebnis=Supi(zahl1,zahl2);break; //Anweisung
case '*' : ergebnis=Multi(zahl1,zahl2);break; //Anweisung
case '/' : ergebnis=Divis(zahl1,zahl2);break; //Anweisung
default: cout<<"unbek. rechenzeichen.."<<endl;
}
e=ergebnis;
cout<<ergebnisausgabe;
}
double Adi(double zahl1, double zahl2) //Definition
{return zahl1+zahl2;}
double Supi(double zahl1, double zahl2) //Definition
{return zahl1-zahl2;}
double Multi(double zahl1,double zahl2) //Definition
{return zahl1*zahl2;}
double Divis(double zahl1, double zahl2) //Definition
{return zahl1/zahl2;}
[red]double ergebnisausgabe(double e)
{return [mm] e;}[\red]
[/mm]
|
|
|
|
Eingabefehler: "{" und "}" müssen immer paarweise auftreten, es wurde aber ein Teil ohne Entsprechung gefunden (siehe rote Markierung)
Hallo!
> #include <iostream>
> using namespace std;
>
> void main (){
> double zahl1,zahl2,ergebnis;
> double e;
> double ergebnisausgabe(double e);
> double Adi(double zahl1, double zahl2),Supi(double zahl1,
> double zahl2),
> Multi(double zahl1,double zahl2),Divis(double zahl1,
> double zahl2); //deklaration
Was ist denn das? Die Prototypen, also die Bekanntmachung der Funktionen gehört ganz an den Anfang des Programms, vor die main(). Weiterhin wäre es zumindest bei den Prototypen gut, wenn du pro Zeile nur einen definierst.
>
> char rechenzeichen;
> cout<<"Eingabe der Rechenaufgabe:";
> cin >> zahl1 >> rechenzeichen >> zahl2;
> switch(rechenzeichen)
> {
> case '+' : ergebnis=Adi(zahl1,zahl2);break;
> //Anweisung
> case '-' : ergebnis=Supi(zahl1,zahl2);break;
> //Anweisung
> case '*' : ergebnis=Multi(zahl1,zahl2);break;
> //Anweisung
> case '/' : ergebnis=Divis(zahl1,zahl2);break;
> //Anweisung
> default: cout<<"unbek. rechenzeichen.."<<endl;
> }
Bei nem unbekannten Rechenzeichen macht die spätere Ergebnisausgabe keinen Sinn. Daher würde ich hier zusätzlich ein
return;
einfügen, dann wird das Programm vorzeitig beendet...
> e=ergebnis;
> cout<<ergebnisausgabe;
Was genau möchtest du hier machnen? Eigentlich reicht ein
cout << zahl1 <<" "<< rechenzeichen << " "<< zahl2 <<" = "<<ergebnis<<endl;
oder
cout << "Ergebnis: "<<ergebnis<<endl;
Soll das in der Ergebnisausgabe-Funktion geschehen, mußt du dieser natürlich alles übergeben, was diese braucht, im simpelsten Fall wäre dass
ergebnisausgabe(ergebnis);
und die Funktion wäre
void ergebnisausgabe(double erg){
cout << "Ergebnis: "<<erg<<endl;
}
> }
> double Adi(double zahl1, double zahl2) //Definition
> {return zahl1+zahl2;}
>
> double Supi(double zahl1, double zahl2) //Definition
> {return zahl1-zahl2;}
>
> double Multi(double zahl1,double zahl2) //Definition
> {return zahl1*zahl2;}
>
> double Divis(double zahl1, double zahl2) //Definition
> {return zahl1/zahl2;}
>
> double ergebnisausgabe(double e)
> {return [mm]e;}[\red][/mm] [/red]
denn diese Funktion tut nicht wirklich was, sie gibt den Übergabewert einfach zurück.
|
|
|
|
|
Status: |
(Mitteilung) Reaktion unnötig | Datum: | 11:55 Mi 28.04.2010 | Autor: | max_e |
vielen dank event für deine ausführliche verbesserung,
jetzt funktioniert es, nochmals danke
gruss [mm] max_e
[/mm]
|
|
|
|