Computer Science, asked by arjun9752, 1 year ago

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.

Test Case

Explanation
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. give me code any programming langauge...........

Answers

Answered by sswaraj04
79

Answer:

#include <iostream>

#include<math.h>

using namespace std;

int main()

{

   int n;

   cin>>n;

   int arr[n][3];

   for(int i=0;i<n;i++)

   {

       cin>>arr[i][0]>>arr[i][1]>>arr[i][2];

   }

   float dis[n];

   for(int i=0;i<n;i++)

   {

       int x=arr[i][0]*arr[i][0];

       int y=arr[i][1]*arr[i][1];

       dis[i]=sqrt(x+y);

   }

   int count=0;

   for(int i=0;i<n;i++)

   {

       for(int j=i+1;j<n;j++)

       {

           if(dis[i]/arr[i][2]==dis[j]/arr[j][2])

               count++;

       }

   }

   cout<<count;

   return 0;

}

Explanation:

I have written in c++

Hope it helps :-)

Similar questions