There are balls along a number line, each ball is represented by a point on the line. Ball moves at velocity () along this number line and is initially at point .
When two balls collide (occupy the same point along the number line), their velocities switch. For example, if ball with velocity collides with ball with velocity , ball will have velocity and ball will have velocity after the collision.
Given each ball's initial distinct position and velocity, find for each ball the sum of the floor of the times that ball collides with another ball. Formally, ball collides with another ball times in total at times . Print, for each ball.
It is guaranteed that whenever two balls collide, the signs of their velocities will be different ().
Input format
- The first line of the input contains a single integer denoting the number of test cases.
- The first line of each test case contains a single integer denoting the number of balls.
- The second line of each test case contains integers denoting the initial position of ball .
- The third line of each test case contains integers denoting the velocity of ball .
Output format
Print integers denoting the being the sum of the floors of each time ball collides with another ball.
Constraints
It is guaranteed that, in the given input, whenever two balls collide the signs of their velocities will be different.
It is guaranteed that the sum of over all test cases is less than or equal to .
No two pairs of balls collide at the same place at the same time.
In the first test case, the balls never collide so the total sum of times will be .
In the second test case, the ball collides exactly ones at , so the sum of the floor of times for each ball will be .
In the third test case, the first collision happens between the 2nd and 3rd balls at time . When they collide, the second ball and third ball switch velocities so the second ball is now traveling at velocity and the third ball is now traveling at velocity . The third ball never hits anything else so it's final value is . The second ball then hits the first ball at and then no balls ever collide again. Thus, the answer for the second ball is and the answer for the second ball is simply
Code(C++):-
Code(JAVA):-
Recommended Post :-
- Swap the adjacent characters of the string
- Double the vowel characters in the string
- Character with their frequency
- Program to find the closest value
- Swap adjacent characters
- Double the vowel characters
- Check valid parenthesis
- Print the characters with their frequencies
- Find closest value
- Word Count
- Program of CaesarCipher
- Program to find the perfect city
- Annual Day | Tech Mahindra coding question
- Find the number of pairs in the array whose sum is equal to a given target.
Full C course:-
Key points:-
- How to set limit in the floating value in python
- What is boolean data type
- How to print any character without using format specifier
- How to check that given number is power of 2 or not
- How to fix limit in double and floating numbers after dot (.) in c++
- How to print a double or floating point number in scientific notation and fixed notation
- How to take input a string in c
- How to reduce the execution time of program in c++.
Cracking the coding interview:-
Array and string:-
Tree and graph:-
Hackerearth Problems:-
- Very Cool numbers | Hacker earth solution
- Vowel Recognition | Hackerearth practice problem solution
- Birthday party | Hacker earth solution
- Most frequent | hacker earth problem solution
- program to find symetric difference of two sets
- cost of balloons | Hacker earth problem solution
- Chacha o chacha | hacker earth problem solution
- jadu and dna | hacker earth solution
- Bricks game | hacker earth problem
- Anti-Palindrome strings | hacker earth solution
- connected components in the graph | hacker earth data structure
- odd one out || hacker earth problem solution
- Minimum addition | Hackerearth Practice problem
- The magical mountain | Hackerearth Practice problem
- The first overtake | Hackerearth Practice problem
- Playing With Characters | Hackerrank practice problem solution
- Sum and Difference of Two Numbers | hackerrank practice problem solution
- Functions in C | hackerrank practice problem solution
- Pointers in C | hackerrank practice problem solution
- Conditional Statements in C | Hackerrank practice problem solution
- For Loop in C | hackerrank practice problem solution
- Sum of Digits of a Five Digit Number | hackerrank practice problem solution
- 1D Arrays in C | hackerrank practice problem solution
- Array Reversal | hackerrank practice problem solution
- Printing Tokens | hackerrank practice problem solution
- Digit Frequency | hackerrank practice problem solution
- Calculate the Nth term | hackerrank practice problem solution
Data structure:-
- Program to find cycle in the graph
- Implementation of singly link list
- Implementation of queue by using link list
- Algorithm of quick sort
- stack by using link list
- program to find preorder post order and inorder of the binary search tree
- Minimum weight of spanning tree
- Preorder, inorder and post order traversal of the tree
MCQs:-
0 Comments