Doraemon and big light(challenge)
Time Limit: 2 sec
Memory Limit: 128000 kB
Memory Limit: 128000 kB
Problem Statement
Gian and Suneo want their heights to be equal so they asked Doraemon's help. Doraemon gave a big light to both of them but the both big lights have different speed of magnifying. Let's assume the big light given to Gian can increase height of a person by v1 m/s and that of Suneo's big light is v2 m/s.
At the end of each second Doraemon check if their heights are equal or not.
Given initial height of Gian and Suneo, your task is to check whether the height of Gian and Suneo will become equal at some point or not, assuming they both started at the same time.
At the end of each second Doraemon check if their heights are equal or not.
Given initial height of Gian and Suneo, your task is to check whether the height of Gian and Suneo will become equal at some point or not, assuming they both started at the same time.
Input
First line takes the input of integer h1(height of gian), h2(height of suneo), v1(speed of Gian's big light) and v2(speed of Suneo's big light) as parameter.
Constraints:-
1 <= h2 < h1<=10000
1 <= v1 <= 10000
1 <= v2 <=10000
Constraints:-
1 <= h2 < h1<=10000
1 <= v1 <= 10000
1 <= v2 <=10000
Output
print "Yes" if their height will become equal at some point (as seen by Doraemon) else print "No".
Example
Sample input:-
4 2 2 4
Sample output:-
Yes
Explanation:-
height of Gian goes as- 4 6 8 10. .
height of Suneo goes as:- 2 6 10..
at the end of 1 second their height will become equal.
Sample Input:-
5 4 1 6
Sample Output:
No
4 2 2 4
Sample output:-
Yes
Explanation:-
height of Gian goes as- 4 6 8 10. .
height of Suneo goes as:- 2 6 10..
at the end of 1 second their height will become equal.
Sample Input:-
5 4 1 6
Sample Output:
No
#code
/*1st approach*/
static boolean EqualOrNot(int h1, int h2, int v1,int v2){
if (v2>v1&&(h1-h2)%(v2-v1)==0){
return true;
}
return false;
}
/* second approach
static boolean EqualOrNot(int h1, int h2, int v1,int v2){
//Enter your code here
if(v1==v2)
return false;
int x = h1-h2;
int y = Math.max(v1,v2) - Math.min(v1,v2);
int c = x/y;
boolean ans = (h1+c*v1) == (h2+c*v2);
return ans;
}
*/
Post a Comment