Compare commits

...

2 Commits

Author SHA1 Message Date
643c524d1b Aufgabe 3 fertig 2026-04-24 01:03:08 +02:00
3b1a8af39d bissl Fortschritt, ich will aber erst Aufg 3 machen 2026-04-23 15:07:56 +02:00
6 changed files with 97 additions and 54 deletions

View File

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

View File

@ -0,0 +1,19 @@
#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);