Задача 787A с сайта codeforces.com.
Задача
Монстр гонится за Риком и Морти на другой планете. Они настолько напуганы, что иногда кричат. Точнее, Рик кричит в моменты времени b, b + a, b + 2a, b + 3a, …, а Морти кричит в моменты времени d, d + c, d + 2c, d + 3c, ….
Монстр поймает их, если в какой-то момент времени они закричат одновременно. Так что он хочет знать, когда он поймает их (первый момент времени, когда они закричат одновременно) или они никогда не закричат одновременно.
Ввод
Первая строка входных данных содержит два целых числа a и b (1 ≤ a, b ≤ 100).
Вторая строка входных данных содержит два целых числа c и d (1 ≤ c, d ≤ 100).
Вывод
Выведите первый момент времени, когда Рик и Морти закричат одновременно, или - 1, если они никогда не закричат одновременно.
Тесты
Ввод
|
Вывод |
20 2 9 19 |
82 |
2 1 16 12 |
-1 |
Код
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 |
#include <iostream> #include <vector> using namespace std; int main() { int a,b,c,d,n,m; vector <int> s; cin>>a>>b; cin>>c>>d; for(int i=0;i<=100;i++) { for(int j=0;j<=100;j++) { n=b+i*a; m=d+j*c; if(m==n) { s.push_back(n); } } } if(s.empty()==true) { cout<<-1; } else cout<<s.at(0); return 0; } |
Решение
В этих моментах времени, заданных прогрессиями, изменяется только коэффициент при a и c. Создадим для них 2 цикла. Так как равных моментов времени может быть много, а нам нужен только первый, создаем вектор и ,когда моменты равны, добавляем в него этот момент. Затем, уже вне цикла, проверяем пустой ли вектор, и в таком случаем выводим -1, так как моменты на данном промежутке не были равны ни разу. Если же вектор непустой, выходим первый элемент вектора. Он и будет искомым первым одновременным криком.
Хорошо, Антон.
Только в дальнейшем согласовывайте со мной публикации, которые делаете по своей инициативе.
Хорошо, Игорь Евгеньевич. Извините, взял пример с Вадима, подумал он уже спрашивал.