From fbbe586d25b1ebaf66fe2e92e1986bb5debf961d Mon Sep 17 00:00:00 2001 From: Syndamia Date: Thu, 19 Oct 2023 19:40:08 +0300 Subject: [w2] Added solutions --- week02/exercise11.cpp | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) create mode 100644 week02/exercise11.cpp (limited to 'week02/exercise11.cpp') diff --git a/week02/exercise11.cpp b/week02/exercise11.cpp new file mode 100644 index 0000000..7d1de63 --- /dev/null +++ b/week02/exercise11.cpp @@ -0,0 +1,21 @@ +#include + +int main() { + // Много не съм ползвал константи в решенията, не защото няма смисъл да се прави, а така някои неща по-лесно се виждат + const int LIGHT_SPEED = 29; + + int timeSent, firstSatelliteCoord, firstSatelliteTimeRecv, secondSatelliteCoord, secondSatelliteTimeRecv; + std::cin >> timeSent >> firstSatelliteCoord >> firstSatelliteTimeRecv >> secondSatelliteCoord >> secondSatelliteTimeRecv; + + int distanceToFirst = (firstSatelliteTimeRecv - timeSent) / 2 * LIGHT_SPEED; + int distanceToSecond = (secondSatelliteTimeRecv - timeSent) / 2 * LIGHT_SPEED; + + // Повтарям логиката тука: имаме 4 възможни точни, първия сателит +- дистаниця и втория сателит +- дистанция + // Понеже данните не лъжат, трябва две от тези 4 възможности да съвпадат, и това проверяваме + // Допускаме че входа е валиден, така че това работи + if (firstSatelliteCoord + distanceToFirst == secondSatelliteCoord + distanceToSecond || + firstSatelliteCoord + distanceToFirst == secondSatelliteCoord - distanceToSecond) + std::cout << (firstSatelliteCoord + distanceToFirst) << std::endl; + else + std::cout << (firstSatelliteCoord - distanceToSecond) << std::endl; +} -- cgit v1.2.3