How I Applied?
I applied through their careers page https://www.deshawindia.com/OpenPositions.shtml .
I got to know about their recruiting through a friend. Then got an invitation for their OffCampus test after a week of applying.
**Hackerrank Test : **
The test was for 100 marks with 90 minutes time limit. The format of the test is as follows:
The first Coding question was easy, something related to array manipulation and implementation. Another one was about finding kth permutation of a string (k<=1e9).
Round 1: CodePair Round 1.5 hr
I got a reply from them after a month of the test. In CodePair Round the interviewer asked me to solve two programming questions. The first one was quite easy and straight forward it said to find the number of ways a given number can be expressed as a sum of more than 1 consecutive natural numbers. You can find the link https://www.geeksforgeeks.org/count-ways-express-number-sum-consecutive-numbers.
The second one was: Given a matrix(n * m) and a queen positioned at (n-1,m/2). Find the number of ways in which the queen can reach cell no. (x,y) in minimum number of moves. There were Q queries of (x,y). The queen can move in any of the eight valid directions in one move. Preprocessing of O(n2) was allowed and queries were supposed to be answered in O(1).
Then there was a small discussion on my projects and some questions regarding polymorphism, Virtual functions were asked along with other OOPS concept.
Round 2: Technical Round 1 hr
This round was also on HackerRank CodePair. I was supposed to solve one programming. The question was: Given stock prizes for N days. Each day you could either buy a stock or sell some/all of the stocks you have purchased previously. It is also allowed to not perform any operation for a day.
Buying a stock will count as a negative addition to profit and selling will count as a positive addition to the profit. Find the maximum profit that could be achieved given the Stock prizes for N days.
Example : [1,5,2,100,3,2]
Buy stocks for first three days = -1 + -5 + -2 = -8
Sell all the stocks on the fourth day = +100*4
Don’t do anything on the fifth and sixth day as there is no way one could sell the bought stock at a higher price. Thus, maximum profit = -8 + 100*4 = 392
My Solution: Find the next maximum Stock price for each day and buy that stock only if there is any available higher prize. So the profit will be:
For each ith day buying a stock ( – stockPrize[i] ) and selling the stock at a later day with highest stock prize ( i.e. +max(stockPrize[i+1,n-1] ) ). This range maximum could be easily computed using suffix maximum, given a solution in linear time.
Apart from this coding question I was asked questions from DBMS, OS, Projects:
Round 3: Technical Round 1.5 hr
This round was also on HackerRank CodePair. Design and implement a class that can be used to allocate and de-allocate a certain amount of memory blocks. The class will initially have a fixed block of memory which will only be used to allocate memory. Say 1024 blocks.
There is no right or wrong answer for the Class Design. They just want to judge you on how you could apply CS fundamentals to solve the problem and are you able to identify some flaws in the design and also they expect you to eventually solve them.
Given a file consisting of millions of records. The data is in a structured format i.e in a tabular format with each record consisting of many attributes.
What is a Trie Data Structure? Explain it’s node structure and working? What is it’s applications?
How will you optimize the memory usage in Trie?
A simple Game Theory question: Given Two Players A and B separated by N number of tiles. In a move, each one can move one or two-step ahead. Who will win if player A starts and each one plays alternately and optimally. The player who is not able to make any move losses the game.
A _ _ _ _ B for n=4
Solution :
If n=1 or 2, A wins in one move. Thus, both n=1 and n=2 are winning states
n=3, B wins as from n=3 we could go to either n=1 or n=2 and both are winning states
Thus if f(n) = 0 if B wins and
1 if A wins
f(n) = 0 if ( f(n-1)==1 and f(n-2)==1 )
f(n) = 1 if( f(n-1)==0 or f(n-2)==0 )
Base cases f(2)=1 and f(1)=1This could be solved in linear time. But if you write down all the values of f() you will find that it decomposes to f(n) = 0 if n is a multiple of 3 otherwise f(n)=1.
After a day or two, I got their call that they are willing to offer me the position.
#interview experiences #d-e-shaw #de shaw #marketing #off-campus #interview