i dont remember the questions of the first interview so i decided to write the second interview after finishing it
its my second interview at google
the interview was at 8:00 PM Cairo time
i am near to the phone waiting for the call
the phone ring at 8:05 PM and one of software engineers at google start talking to me
the interview was about 45 minutes
he ask me the following questions
- my work experience as per my cv
- what is my prefered programming language
- what the diffrence between the following three java keywords (final,finally and finalize)
- implement algorithm that find all pairs of integers in an interger array that the sum of each pair equal to specific value.
my answers
- regards my work experience i am now working at TE-Data.one of the largest internet service provider (ISP) in egypt. i fill the position of Java Software Developer.we are mantain and develop customized software to support the company business regards ADSL services. google interviewer also asked me about the period i spend there at TE-Data and i say i am their from 4 months i joined TE-Data at June 2008 before TE-Data i was doing military service through this period i work as part time J2ME Developer at Telecom-Arabia
- my prefered programming language is Java as per my study and work experience
- the three java keywords
-->final is java keword and have three diffrent meaning in three context. first if i declare avariable as final then its constant its value will not change through the life time of the program.second if method its declared final the the subclasses cannot override it.third if the class declared as final it canot be extended
--->finally is java keyword that is used with try catch statement its used to closed any open connection or any code that must run if error happen or not.
-->finalize is java method that is called when the object is reclaimed from the memory its like c++ destructor we put code that free system resources in it but its not preferable to account on this method as we are not sure when this method will be called. - algorthim that find the pairs of integers that their sum will equal specific value. i say that the straightforward solution is through two for loops that take each array elment and sum it to every element in the array and i provided this code to support my words
int a[];//this array hold list of integers
int x;//this variable hold the sum
for(int i=0;i<a.lenght;i++)
{
int sum=a[i];
for(int j=0;j<a.lenght;j++)
{
if(i==j)
continue;
if((sum+a[j])==x)
print(i,j);
}
}
then google interviewer this code will repeat the printing of the pairs
and asked how many times it will repeat two,three,...
i sayed it will print every pairs two times
as each two pairs will be compared two times
then i say to modify the inner loop instead of intializing j=0 to i+1
and the algorthim will look like that
int a[];//this array hold list of integers
int x;//this variable hold the sum
for(int i=0;i<a.lenght;i++)
int sum=a[i];
for(int j=i+1;j<a.lenght;j++)
and ask about the time complexity of the algorithm i sayed its n square (n2)
he asked about to get it faster (enhancing its performance)
i say can we assume the array is sorted he say assume its sorted then i say we will take every element in the array and subtract this element from the required value then do binary search on this value and i provide the following code to support my words
int a[];//this array hold list of integers
int x;//this variable hold the sum
for(int i=0;i<a.lenght;i++)
{
int secondPair=x-a[i];
int j=binarySearch(secondPair,i+1);
if(index!=-1)
print(i,j);
}
he says ok and good then asked about the time complexity i says its (nlogn)
then he asked again what about if the array is not sorted
the i say we will sort it first using quicksort or mergesort its
then we will do the above algorithm again
then he asked about the time complexity i says
sort will take (nlogn)
pair search will another (nlogn)
then its (2nlogn) and we can ignore the constant factor then the algorithm complexity still (nlogn)
he says good
and asked me if i have any questions
and i says thanks and i am happy from the call
7 comments:
that's good new well done basha, and we hope to see u as google developer soon.
Realy this is a good News to my brother Ahmed Sharaf and ISA you will be the top developer on Google and we want to hear more about you on future !
good job ya kbeer
bs ll 3elm fe 6aree2a ta2reban O(n) :D
Hashset set;
for(int i: arr){
set.add(i);
}
for(int i:arr){
int j = value - i;
if(j>=i && set.contains(j)){
print(i , j);
}
}
yalla ya 3mena ay 5edma :D
w 2oly eeh commentatk 3ala el code da
salam
Dear Ahmed:
Nice post, but i need to share some thing about google, google main concentration is about Algorithms, and they need the best not the better solution :), they are not playing, so for example i found a question that need a search algorithm that is O(n) :), and there is a one by the way, so enhancing algorithm skills is very important, i recommend topcoder.com
Dear Mohammed,
Hashset set;
for(int i: arr){
set.add(i);
}
with respect to this code
i dont think its complexity is o(n)
why
every insertion in the set i think it need search
????????????
Alsalam alikom abo 7meed,
Really well done and good skills and ability to think of solutions dynamically so, Congrats :)
Regarding Mohamed's reponse,
he used a HashSet, and using it means u get the element u search for in just 1 hit, which means just O (1), so the overall performance is O (n).Remember HashSet uses hashing :), one hit for any element.
Well done and hope to hear about an official offer.
Salam
coooooooooooooooooooool
ya mannnnnnnnnnnnnnnnn
ISA u will be a man of ur Dreams
I found this link By luck
alf alf mabrooooook 3la ur weddings
ISA we will see small sharaf
Mohamed Abd EL Megeed
Post a Comment