Compare commits

..

No commits in common. "643c524d1b7b8c37f527aed1ae4bb3a164222ae5" and "be77aebb258392c51345dfaaf372f9448ea5bd75" have entirely different histories.

6 changed files with 54 additions and 97 deletions

View File

@ -1,9 +0,0 @@
const float* const wert
Welche Bedeuting haben das erste und zweite const?
wert ist ein konstanter Zeiger auf ein konstanten float.
1. const: es ist ein konstanter float
2. const: es ist ein konstanter zeiger
Welchen Nutzen könnte die Verwendung von const an den beiden Stellen bieten?
An der 1. Stelle: sichergehen, dass der Wert mit den gearbeitet wird nicht geändert wird
An der 2. Stelle: sichergehen, dass der Zeiger nicht auf etwas anderes zeigt, womit sich der Wert ändern würde.

View File

@ -1,25 +1,10 @@
#include <stdio.h>
#include "summe.h" #include "summe.h"
#include <iostream>
#include <vector>
int main() { int main()
/* const int N = 4; {
const int N = 4;
const float daten[N] = {1.0f,2.0f,3.0f,4.0f}; const float daten[N] = {1.0f,2.0f,3.0f,4.0f};
float summe = berechneSumme(daten,N); float summe = berechneSumme(daten,N);
printf("Summe = %f\n", summe); */ printf("Summe = %f\n", summe);
string name;
int anzahlSummanten;
int hilfvar;
vector<int> summanten;
cout << "Was ist dein Name?" << endl;
cin >> name;
cout << "Hallo " << name << ", Wie viele Zahlen willst du addieren?" << endl;
cin >> anzahlSummanten;
for (int i = 0; i < anzahlSummanten; i++) {
cout << "Der " << i + 1 << ". Summant ist:" << endl;
cin >> hilfvar;
summanten.push_back(hilfvar);
}
cout << name << ", die Summe ist: " << berechneSumme(summanten) << endl;
cout << "Auf Wiedersehen " << name << endl;
} }

View File

@ -1,13 +1,8 @@
#include "summe.h" #include "summe.h"
/* float berechneSumme(const float *const wert, int anzahlWerte) { float berechneSumme(const float* const wert, int anzahlWerte)
{
return (anzahlWerte) ? *wert+berechneSumme(wert+1, anzahlWerte-1) : 0; return (anzahlWerte) ? *wert+berechneSumme(wert+1, anzahlWerte-1) : 0;
} */ }
int berechneSumme(vector<int> myvector) {
int summe;
for (unsigned int i = 0; i < myvector.size(); i++) {
summe += myvector[i];
}
return summe;
}

View File

@ -1,8 +1,6 @@
#ifndef __SUMME_H #ifndef __SUMME_H
#define __SUMME_H #define __SUMME_H
#include <vector>
using namespace std;
/** /**
* Berechnet die Summe ueber eine Menge von Werten. * Berechnet die Summe ueber eine Menge von Werten.
* @param wert Werte * @param wert Werte
@ -10,5 +8,5 @@ using namespace std;
* @return Summe * @return Summe
*/ */
float berechneSumme(const float* const wert, int anzahlWerte); float berechneSumme(const float* const wert, int anzahlWerte);
int berechneSumme(vector<int> myvector);
#endif #endif

View File

@ -1,38 +1,45 @@
#include "flugkurve02.h"
#include <iostream> #include <iostream>
using namespace std; using namespace std;
Vektor mulVektor(const Vektor &vec, const float &skalar){ int main()
Vektor ergebnis = {vec.x * num, vec.y * num}; {
return ergebnis; // Körper:
} float masse = 10; // [kg]
float xPosition = 0; // [m]
float yPosition = 0; // [m]
float xGeschwindigkeit = 10; // [m/s]
float yGeschwindigkeit = 10; // [m/s]
Vektor addVektor(Vektor vec1, Vektor vec2) { // Parametrierung der auf den Körper wirkende Kräfte:
Vektor erg = {vec1.x + vec2.x, vec1.y + vec2.y}; const float X_BESCHLEUNIGUNG_GRAVITATION = 0; // [m/s^2]
return erg; const float Y_BESCHLEUNIGUNG_GRAVITATION = -9.81; // [m/s^2]
} const float REIBUNGSKOEFFIZIENT = -5; // [kg/s]
Koerper bewegeKoerper(Koerper korp, Vektor gesamtkraft, float dt) { // Sorgt dafür, dass 2 Nachkommastellen angezeigt werden:
cout << fixed;
cout.precision(2);
// Simulation:
const float dt = 0.1; // [s]
for(;;)
{
cout << "(" << xPosition << "," << yPosition << ")" << endl;
// Berechnung der Beschleunigung aus der Kraft // Berechnung der Beschleunigung aus der Kraft
float xBeschleunigung = gesamtkraft.x / korp.masse; float xBeschleunigung = xGeschwindigkeit * REIBUNGSKOEFFIZIENT / masse + X_BESCHLEUNIGUNG_GRAVITATION;
float yBeschleunigung = gesamtkraft.y / korp.masse; float yBeschleunigung = yGeschwindigkeit * REIBUNGSKOEFFIZIENT / masse + Y_BESCHLEUNIGUNG_GRAVITATION;
// Ermittlung der neuen Geschwindigkeit // Ermittlung der neuen Geschwindigkeit
korp.geschwindigkeit.x += dt * xBeschleunigung; xGeschwindigkeit += dt * xBeschleunigung;
korp.geschwindigkeit.y += dt * yBeschleunigung; yGeschwindigkeit += dt * yBeschleunigung;
// Ermittlung der neuen Position // Ermittlung der neuen Position
korp.position.x += dt * korp.geschwindigkeit.x; xPosition += dt * xGeschwindigkeit;
korp.position.y += dt * korp.geschwindigkeit.y; yPosition += dt * yGeschwindigkeit;
return korp;
}
void ausgabeKoerper(Koerper korp){ if(yPosition<=0)
cout << "x = " << korp.position.x << "y = " << korp.position.y; {
break;
}
} }
void ausgabeVektor(Vektor vec){
cout << "x = " << vec.x << endl;
cout << "y = " << vec.y << endl;
} }

View File

@ -1,19 +0,0 @@
#pragma once
// Parametrierung der auf den Körper wirkende Kräfte:
struct Vektor {
const float x; // [m/s^2]
const float y; // [m/s^2]
};
// Körper:
struct Koerper {
float masse; // [kg]
Vektor position;
Vektor geschwindigkeit;
};
Vektor addVektor(Vektor vec1, Vektor vec2);
Vektor mulVektor(Vektor vec, float skalar);
Koerper bewegeKoerper(Koerper korp, Vektor gesamtkraft, float dt);
void ausgabeKoerper(Koerper korp);
void ausgabeVektor(Vektor vec);