CODEVITA PREVIOUS YEAR QUESTION / MOCKVITA 2020 PROBLEM "Collision Course" [Solved]

              PROBLEM: COLLISION COURSE

Problem Description

On a busy road, multiple cars are passing by. A simulation is run to see what happens if brakes fail for all cars on the road. The only way for them to be safe is if they don't collide and pass by each other. The goal is to identify whether any of the given cars would collide or pass by each other safely around a Roundabout. Think of this as a reference point O ( Origin with coordinates (0,0) ), but instead of going around it, cars pass through it.
Considering that each car is moving in a straight line towards the origin with individual uniform speed. Cars will continue to travel in that same straight line even after crossing origin. Calculate the number of collisions that will happen in such a scenario.
Note : - Calculate collisions only at origin. Ignore the other collisions. Assume that each car continues on its respective path even after the collision without change of direction or speed for an infinite distance.

Constraints

1<=C<=10^5
-10^9 <= x,y <= 10^9
0 < v < 10^9.

Input Format

The first line contains an integer C, denoting the number of cars being considered that are passing by around the origin.
Next C lines contain 3 space delimited values, first two of them being for position coordinates (x,y) in 2D space and the third one for speed (v).

Output

A single integer Q denoting the number of collisions at origin possible for given set of cars.

Timeout

1

Test Case

Example 1
Input
5
5 12 1
16 63 5
-10 24 2
7 24 2
-24 7 2
Output
4
Explanation
Let the 5 cars be A, B, C, D, and E respectively.
4 Collisions are as follows -
1) A & B.
2) A & C.
3) B & C.
4) D & E.

SOLUTION:

N = int(input())
lis = [0]*N
for i in range(N):
    x, y, v = list(map(int, input().split()))
    t = ((x*x) + (y*y))/(v*v)
    lis[i] = t

l = sorted(lis)
count = 0
for i in range(0,N-1):
    for j in range(i+1,N):
        if l[j]%l[i] == 0:
            print(i,j)
            count+=1

print(count)

Comments