#include #include #include //Dieses Programm berechnet wann sich 2 Autos auf einer Straße treffen wobei die Geschwindigkeit beider Autos schrittweise erhöht werden kann. int main() { std::string input; long double speed, distance, speedOppositeTrack, position; std::cout << "Geben sie die Strecke der Landstra\xE1 \be in km ein: "; do { getline(std::cin, input); std::stringstream(input) >> distance; if(distance<0)std::cout << "\nERROR: Die Strecke muss gr\x94\xE1 \ber als 0 km sein. Gebe die Strecke erneut ein: "; }while(distance<0); std::cout << "Geben sie ihre Startgeschwindigkeit in km/h ein: "; getline(std::cin, input); std::stringstream(input) >> speed; if(0>speed>200) { std::cout << "\nERROR: Die Geschwindigkeit muss gr\x94\xE1 \ber als 0 km/h sein und darf 200 km/h nicht \x81 \bberschreiten."; getchar(); return(1); } std::cout << "...und nun die Geschwindigkeit der Autos der gegen\x81 \bberliegenden Fahrbahn: "; getline(std::cin, input); std::stringstream(input) >> speedOppositeTrack; if(0>speedOppositeTrack>200) { std::cout << "\nERROR: Die Geschwindigkeit muss gr\x94\xE1 \ber als 0 km/h sein und darf 200 km/h nicht \x81 \bberschreiten."; getchar(); return(1); } std::cout << "\nGib nach jeder Ausgabe +/- ein um deine Geschwindigkeit um 5 km/h zu verringern oder erhöhen\nSie begegnen unterwegs folgenden Autos:\n"; for(long double time = distance/(speed+speedOppositeTrack), position = time*speed; position<=distance; position += speedOppositeTrack/(120*(speed+speedOppositeTrack))*speed, time += speedOppositeTrack/(120*(speed+speedOppositeTrack))) //Formel für t nicht ausreichend. { if(position>ULLONG_MAX) { std::cout << "ERROR: Begegnung kann nicht berechnet werden."; break; } std::cout << (int)time << "h:" << (int)(time*60)%60 << "min:" << (int)(time*3600)%60 << "sec: " << position << "km"; getline(std::cin, input); if(input=="+") speed += 5; if(input=="-") speed -= 5; if(-speed>speedOppositeTrack) break; } std::cout << "PROGRAMMENDE!"; getchar(); return(0); }