matheraum.de
Raum für Mathematik
Offene Informations- und Nachhilfegemeinschaft

Für Schüler, Studenten, Lehrer, Mathematik-Interessierte.
Hallo Gast!einloggen | registrieren ]
Startseite · Forum · Wissen · Kurse · Mitglieder · Team · Impressum
Forenbaum
^ Forenbaum
Status Schulmathe
  Status Primarstufe
  Status Mathe Klassen 5-7
  Status Mathe Klassen 8-10
  Status Oberstufenmathe
    Status Schul-Analysis
    Status Lin. Algebra/Vektor
    Status Stochastik
    Status Abivorbereitung
  Status Mathe-Wettbewerbe
    Status Bundeswettb. Mathe
    Status Deutsche MO
    Status Internationale MO
    Status MO andere Länder
    Status Känguru
  Status Sonstiges

Gezeigt werden alle Foren bis zur Tiefe 2

Navigation
 Startseite...
 Neuerdings beta neu
 Forum...
 vorwissen...
 vorkurse...
 Werkzeuge...
 Nachhilfevermittlung beta...
 Online-Spiele beta
 Suchen
 Verein...
 Impressum
Das Projekt
Server und Internetanbindung werden durch Spenden finanziert.
Organisiert wird das Projekt von unserem Koordinatorenteam.
Hunderte Mitglieder helfen ehrenamtlich in unseren moderierten Foren.
Anbieter der Seite ist der gemeinnützige Verein "Vorhilfe.de e.V.".
Partnerseiten
Weitere Fächer:

Open Source FunktionenplotterFunkyPlot: Kostenloser und quelloffener Funktionenplotter für Linux und andere Betriebssysteme
StartseiteMatheForenC/C++Funktion für Betrag
Foren für weitere Schulfächer findest Du auf www.vorhilfe.de z.B. Informatik • Physik • Technik • Biologie • Chemie
Forum "C/C++" - Funktion für Betrag
Funktion für Betrag < C/C++ < Programmiersprachen < Praxis < Informatik < Vorhilfe
Ansicht: [ geschachtelt ] | ^ Forum "C/C++"  | ^^ Alle Foren  | ^ Forenbaum  | Materialien

Funktion für Betrag: Frage (beantwortet)
Status: (Frage) beantwortet Status 
Datum: 16:57 So 16.12.2012
Autor: charlene80

Hallo
Ich soll eine Funktion schreiben, bei der ich den Betrag einer eingegebenen Zahl berechnen kann.


Ich habe folgendes geschrieben:

#include <stdio.h>

float betrag(float x)
{
if (x < 0) {
x = x * (-1);
}
return x;
}

int main() {
float h;
float y;
printf("zahl eingeben [mm] \n"); [/mm]
scanf("%f",&h);
y=betrag(h);
[mm] printf("Betrag:\n",y); [/mm]
}

Wenn ich das Programm allerdings ausführe, wird mir keine Zahl ausgegeben sondern einfach nur Betrag:
danach kam nichts mehr.
Ich steh echt auf dem schlauch bei solch einer relativ einfachen Aufgabe. Ich hoffe mir kann jemand den Fehler zeigen.

        
Bezug
Funktion für Betrag: Antwort
Status: (Antwort) fertig Status 
Datum: 17:46 So 16.12.2012
Autor: link963

Eingabefehler: "{" und "}" müssen immer paarweise auftreten, es wurde aber ein Teil ohne Entsprechung gefunden (siehe rote Markierung)

> Hallo

Hallo.

>  Ich soll eine Funktion schreiben, bei der ich den Betrag
> einer eingegebenen Zahl berechnen kann.
>  
>
> Ich habe folgendes geschrieben:
>  
> #include <stdio.h>
>  
> float betrag(float x)
>  {
> if (x < 0) {
>   x = x * (-1);
>   }
>   return x;
>  }
>  
> int main() {
>   float h;
>   float y;
>   printf("zahl eingeben [mm]\n");[/mm]Eingabefehler: "{" und "}" müssen immer paarweise auftreten, es wurde aber ein Teil ohne Entsprechung gefunden (siehe rote Markierung)


>   scanf("%f",&h);
>   y=betrag(h);
>      printf("Betrag:\n",y);

Hier hast du dein Umwandlungszeichen "%f" vergessen.

>  }
>  
> Wenn ich das Programm allerdings ausführe, wird mir keine
> Zahl ausgegeben sondern einfach nur Betrag:
>  danach kam nichts mehr.
>  Ich steh echt auf dem schlauch bei solch einer relativ
> einfachen Aufgabe. Ich hoffe mir kann jemand den Fehler
> zeigen.

Grüße link963

Bezug
                
Bezug
Funktion für Betrag: Frage (beantwortet)
Status: (Frage) beantwortet Status 
Datum: 20:06 So 16.12.2012
Autor: charlene80

Oh ja sowas dummes :)
Wenn ich jetzt aber als Zahl 30.654 eingebe , bekomme ich als Betrag heraus: 30.653999 heraus.

Wo liegt der Fehler bzw was muss ich verändern, damit ich die exakte Lösung bekomme?

Bezug
                        
Bezug
Funktion für Betrag: Antwort
Status: (Antwort) fertig Status 
Datum: 20:35 So 16.12.2012
Autor: link963

Ja, das liegt daran, dass bei der Umrechnung in Maschinenzahlen der Speicher nicht mehr ausreicht beim float(32-bit) um die Nachkommastellen exakt darzustellen.

Versuch es mal mit dem Datentyp double (64-bit).

Liebe Grüße
link963

Bezug
                                
Bezug
Funktion für Betrag: Frage (beantwortet)
Status: (Frage) beantwortet Status 
Datum: 21:58 So 16.12.2012
Autor: charlene80

Und was für ein Umwandlungszeichen brauch ich dann an Stelle von %f?

Bezug
                                        
Bezug
Funktion für Betrag: Antwort
Status: (Antwort) fertig Status 
Datum: 22:03 So 16.12.2012
Autor: link963

Dann musst du %lf nehmen.

Bezug
Ansicht: [ geschachtelt ] | ^ Forum "C/C++"  | ^^ Alle Foren  | ^ Forenbaum  | Materialien


^ Seitenanfang ^
www.schulmatheforum.de
[ Startseite | Forum | Wissen | Kurse | Mitglieder | Team | Impressum ]