A set of N billiard balls are set on a one-dimensional
table. The table is 1 meter long,

set north-south with two pockets at either side. Each ball
has zero width and there is

no friction so it is moving with a fixed velocity of either
northward or southward and

bounces back in a perfect elastic collision from other
balls it encounter on its way (or

drop into one of the pockets).


Your job is to keep track of the balls movements.

Task
Please write a program that gets the initial place, speed
and direction of all

the balls and gives the position of a specific ball after t
seconds.




Input
The first line contains the number of scenarios.

Each one of the other lines in the input contains a
scenario:

The first number, N, is the number of balls; followed by N
pairs of numbers: the

distance in centimeters from the south end of the table and
the speed (positive speed

meaning it moves northward); the last two numbers are the
number i of the target ball

you should track and the time T in seconds.


Output
The output is a single number for each line which is the
place (distance in centimeters

from the south end of the table) of the tracked ball after
T seconds.
Note: There is no new line character at the end of the
result.


Sample Input
5

1 50 1 1 1000

1 50 1 1 6

1 60 -2 1 6

2 10 1 95 -1 2 30

2 10 1 95 -1 2 60


Sample Output
100

56

48

65

70


No Answer is Posted For this Question
Be the First to Post Answer

Post New Answer

More C Interview Questions

what is a far pointer

12 Answers   ABB, DRDO, ITI, Maruti Suzuki, Steel Plant, TCS, Toyota, Vivo Mobiles,


How is = symbol different from == symbol in c programming?

0 Answers  


What is a pointer value and address in c?

0 Answers  


When should a far pointer be used?

0 Answers   Aspire, Infogain,


m=++i&&++j(||)k++ printf("%d"i,j,k,m)

1 Answers   ABC,






What is the difference between typeof(foo) and myFoo.GetType()?

2 Answers   Synergy,


f1() { f(3);} f(int t) { switch(t); { case 2: c=3; case 3: c=4; case 4: c=5; case 5: c=6; default: c=0;} value of c?

5 Answers   Geometric Software,


p*=(++q)++*--p when p=q=1 while(q<=6)

0 Answers   KINPOE,


An expression to whose value an operater is applied a) operand b) variable c) constant d) all of the above

0 Answers  


Describe how arrays can be passed to a user defined function

0 Answers  


Tell me what is the purpose of 'register' keyword in c language?

0 Answers  


hi to every one .. how to view table pool after creating the pooled table? plz help me.. if any knows abt this ..

0 Answers  


Categories