Just aced my interview with Amazon today (got an email within minutes after the interview that I was selected to move on to the final panel interview). Thanks so much for these videos, def helped get me in the right mindset and made the coding portion of the interview a breeze.
@harryhopkinson1623 жыл бұрын
Did you get the job? If so congratulations!
@hhcdghjjgsdrt2352 жыл бұрын
bro party !!!!
@bhaveshgavali5312 жыл бұрын
Hi
@AnthonyLauder4 жыл бұрын
This is essentially the final stages of a merge sort, with one list starting on the left, and the other starting on the right.
@shahman13 жыл бұрын
that's interesting
@markj.75573 жыл бұрын
Yup Was the first idea I had as well. Allocate 2x input. Loop over the input and store the negative numbers in the first list and positive in the 2nd. Memory consumption is larger for this case. But end step is just merge the two lists. Original list could be used for this to maintain 3N memory complexity and 2N run time.
@umutti114 жыл бұрын
Nick, you are the best! I’m a software developer over 7 years and I’d watched so many empty talks and crappy solutions from other people for data structure problems. You teach the technique to solve a problem rather than useless looping, mapping ext... Thanks man! Keep up the great work!
@davidhahn73914 жыл бұрын
youtube algorithm picks up another algo video
@tannerbarcelos68804 жыл бұрын
David Hahn sounds like like recursion right there lmao
@VKD0074 жыл бұрын
@@tannerbarcelos6880 its a pointer
@52.yusrilihsanadinatanegar794 жыл бұрын
@@tannerbarcelos6880 yeah, it's like like like recursion there
@maythecodesbewithyou294 жыл бұрын
yup
@maruf_r3 жыл бұрын
CanAlgolism
@WhatIsThisAllAbout4 жыл бұрын
I love to watch your tutorials. It gives me a sense of relief each time I watch it. Not to mention that they are extremely helpful. I’m preparing to work at faang and every morning I come to this channel as a pilgrim
@ThereIsNoSpoon6784 жыл бұрын
And all of my friends accused my teachers, saying that we would never use Math as an adult. Because my computer will be my calculator...
@ZeusMoosePlays2 жыл бұрын
I am currently going through the software developer hiring process. I have lots of feelings of imposter syndrome and doubt. However, your solutions and thought process are fantastic and allow me to relate to you and help me get over my anxiety. This has been such a help to gain confidence. You rock I would love for you to bring these back wherever you are in life right now. Thanks man
@CST19923 жыл бұрын
Nice one. If you search for a Google interview question(from Google itself), this version is also shown there(find the two values in an array that add up to a given sum, in linear time). Note that this solution only works if the values in the input are sorted. If they are not then you cannot guarantee that the pointers are going to be pointing to the smallest/largest values.
@cappuccinopapi30384 жыл бұрын
I could binge 4 seasons of this
@akhila55973 жыл бұрын
same
@Bskater9523 жыл бұрын
Haha! Facts
@danieltsikata28984 жыл бұрын
Great lesson Nick. Another way to optimize this code even better is to loop through the array halfway. This will still give us O(n) for both time and space complexity. Below is my solution (Code in JavaScript btw): function sortedSquareArr(A) { const sortedArr = new Array(); let first = 0; let last = A.length - 1; let i = last; // O(n) - Time complexity // O(n) - Space complexity while(first
@TheRealisticNihilist4 жыл бұрын
You could modify the space complexity by keeping track of the current number as a variable and modifying the input array if the solution required lowest possible space complexity as well.
@GabrielPerez-ml2go4 жыл бұрын
Yours is better but I'll say what my idea was. I was thinking binary search the first positive number and save the index. Then I would compare the negative values on the left vs the positive one on the right and same idea as yours but constructing the output from smallest to biggest. Once either one of the pointer reached an end of the input array just fill in the squares of the side that wasn't done yet. Searching: log(n) Construction: n Run time: log(n)+n = O(n) What I said, yours is truly linear but I just wanted to share my idea. Great type of videos, I like them. Keep the good work and explanation method, mentioning the trivial solution is always a good starting point, I like that about the way you solve these
@brunokawka4 жыл бұрын
I've literally approached that the same way. Binary search for the index of the first positive value or smallest negative (in case there were no positive ones), and maintain two pointers; right for the found index, and left for right-1. Then just simply comparing whether left or right should be pushed first into a newly created array.
@moai8344 жыл бұрын
Basically we are doing one iteration of merge sort at the end: 1. split list into two sorted halves 2. merge them -- I like this solution better.
@GustavoCevalhos4 жыл бұрын
Hi! You would be searching N times in the input, which would lead to N*Lg(N) overall time complexity.
@brunokawka4 жыл бұрын
@@GustavoCevalhos in the given approach you only need to perform a binary search once. Just to find a starting index. The comparison itself runs in the linear time. Hence it's O(n + logn) => O(n) overall
@GustavoCevalhos4 жыл бұрын
@@brunokawka True! I misread the explanation, you are correct :)
@АркадійЦиганов4 жыл бұрын
Actually u do one extra calculation which is abs() , couse u can just square both compare them put larger in output array and put smallest in var to compare with the next one from other side
@madghostek30264 жыл бұрын
I'm happy because I managed to figure it out, I once saw somewhat simmilar problem, where you're given two sorted arrays of n size, and you want to find a pair of numbers x and y, one from each array, such that x+y=m. You would put one pointer i on the start of first array and j on the end of second one, and if sum>m then decrease j, if sum
@minhazulislam46824 жыл бұрын
just looking at 6:55, I paused and opened pycharm. I tried once, didn't work. Debugged in two places and it worked!! thanks nick for making these videos.
@AR-yr5ov4 жыл бұрын
The whole time I thought the input wouldn't be sorted.
@memespdf4 жыл бұрын
Yeah. I was so confused at the beginning because I couldnt think of a solution that would be better than O(N log n) because in every case you still have to sort the numbers. The problems got so much easier with the realization that the numbers are sorted...
@michaelA-d3m4 жыл бұрын
Yeah
@iradnuriel90874 жыл бұрын
If the input isn’t sorted there is no solution better than O(nlog(n)) , it is easy to prove: Assume that there is a solution in o(nlog(n))(way better than O(nlog(n))) so I can sort any array in this time complexity by first taking the sqrt of any element then running the solution for this problem , but we know that you can’t sort arrays in better than O(nlog(n)), contradiction. Q.E.D.
@arnabmitra084 жыл бұрын
@@iradnuriel9087 Given that the range of input is between -10000 and 10000, you can use counting sort for linear time sort.
@motiyanshekhar20024 жыл бұрын
@@arnabmitra08 that is exactly what came to my mind It's much simpler than this pointer stuff anyway.
@bishwanayak4 жыл бұрын
This optimized approach is only possible if input array starts with highest negative and end with highest positive number, ie, the input is sorted either in increasing or decreasing order.
@naturallyweird6614 жыл бұрын
Use two pointers ... One at the end of the negative half ( move towards right) One at the starting of the positive half and merge the two halves ( neglect the negative sign while merging moves to left ) Place the merged ones in output array Later square the merge array or do it while merging Return it back Voila O(n)
@youtuberlast82814 жыл бұрын
int numbers[] = {-3,-4,1,2,3,1}; algorithm not working for this input .Works only if the largest element is at the left and not somewhere else. I think you also have to check the last number with any new greater element and then swap them both.
@n0ame1u13 жыл бұрын
We just need the merge from mergesort between the positive side of the array and the absolute value of the negative side in reverse, and square each element.
@purnendutiwari95704 жыл бұрын
hey bro...u r doing gud .... keep updating by these type of questions.......
@imlovinit12324 жыл бұрын
For loop of the array which iterated through the size of the array, find number closest to zero, and work backwards. Keep track of lowest, highest, and previously sorted number to make it quicker, then, once sorted, a while or for loop to square each element in the array.
@muhammadrizwan49994 жыл бұрын
This algorithm will work if the input array is sorted. We can use modified counting sort algorithm to solve the problem for unsorted input array. It'll take linear time. Maybe I'm wrong.
@aertyty39004 жыл бұрын
If there's an O(n) solution for an unsorted array, we can input some positive integers, then apply this algorithm and sqrt each member, in output we'll get an original sorted array and it will work for O(n), but sorting is actually O(n*log n)
@muhammadrizwan49994 жыл бұрын
@@aertyty3900, count sort and redix sort take linear time (it seems linear) and in required output all numbers are positive. If we take square for each element in array, it'll be done in O(n) and then apply one of these sorting algorithms. It's my thought and I'm not professional programmer.
@aertyty39004 жыл бұрын
@@muhammadrizwan4999 I meant that for the given bounds both algorithms should work but if number length is unlimited it will run out of memory
@muhammadrizwan49994 жыл бұрын
@@aertyty3900 yes and we are sacrificing memory for speed. My bad I wasn't able to understand your previous reply.
@abhishekbalawan68173 жыл бұрын
Second approach will not for input (1,-4,7,-2,5,3,-6). I mean, if elements(abs values) are not arranged in decreasing and increasing order.
@mDevinm4 жыл бұрын
please don’t ever stop making these videos. These help so much with learning and you explain everything with such good detail, I can follow along. Thank you!!!
@halvard12184 жыл бұрын
6:07 Hmm. 36 < 25
@Maaruks3 жыл бұрын
This is a nice Coding Interview Question. I had an interview at Facebook and I failed it because I didn't know O(n) algorithm for a much complex problem.
@mumen_rider42094 жыл бұрын
If both left and right values are equal, we can increment left and decrement right i and can sort the values in result array ,except when they are equal
@samridhsinha11264 жыл бұрын
You could just look for the 1 positive number and place a pointer on the positive side and one on the negative. Now just sq the values on either side see compare which is smaller and add that to the op array
@LukeDupin4 жыл бұрын
Small tweak of merge sort is best. Find the first negative and first positive. Pad output array, start stepping positive/negative side, insert the smallest. This method avoids using the Math.Abs() and will be faster. O(N).
@LoganKearsley4 жыл бұрын
There is a way around the n log n complexity of sorting: the problem explicitly bounds the range of inputs, so you can use a linear-time radio sort. It would be dumb, but you could do it.
@sanderschat4 жыл бұрын
Do a time execution from both code options to show the conclusion of being faster.
@aswins25294 жыл бұрын
2nd method will be faster, it's only taking 1 parse through the array, so N. In first case we were going through the array to square each element, so the time complexity is already N + sorting time
@Chr0n0s384 жыл бұрын
There's no need, he gave the time complexity. The O(n^2) solution can on occasion be faster than O(n), so execution time doesn't tell you much unless you run it on a sufficient number of inputs.
@ClearerThanMud4 жыл бұрын
Nice. This wouldn't improve the complexity, but you could improve performance by simply draining the remaining numbers once you have hit the boundary rather than continuing to check each number.
@bhaveshgavali5312 жыл бұрын
I think on 6th line of second optimised code there should be Math.abs [right] as well, because as you said array full of negative numbers is a valid input.
@bencekovacs87264 жыл бұрын
Even though i understand that your algorithm is clearer to read, but I must point out two things: - you are calling Math.abs each iteration, which is not ideal. you'll have to square it anyway, calling abs is 100% unnecessary. - you aren't really taking advantage of having a sorted array properly. After all the negative (or positive) numbers are "consumed" you know for sure that you can just consume all the leftover numbers in order. pros of mine: - takes less if()s - has no dependency - ifs are faster to evaluate cons of mine: - harder to reaad - took me a bit more time, which is obviously not ideal in an interview int[] sortedSquaredArray(int[] array) { int i = 0; int length = array.length; //square negative ones first for (; (i < length) && (array[i] < 0); i++) { //by naming the arrayaccess value, you don't need to access the array 2 times, only once int val = array[i]; array[i] = val * val; } int[] result = new int[length]; int l = 0; int left = i-1; int right = i; //i'm iterating from the inside, not the outside like you do. while (left >= 0 && right < length) { int leftValue = array[left]; //by naming the arrayaccess value, you don't need to access the array 2 times, only once int rightValue = array[right]; int rightSquaredValue = rightValue * rightValue; if (leftValue < rightSquaredValue) { result[l++] = leftValue; left--; } else { result[l++] = rightSquaredValue; right++; } } //when we get to the end of the minuses or the pluses, we might have a bunch of numbers left. //these numbers are all sorted they need 0 checking, they just need to be added to the result array. if(left >= 0){ for (; left >= 0; left--) { result[l++] = array[left]; } return result; } for (; right < length; right++) { int val = array[right]; result[l++] = val * val; } return result; } please notice me :D
@alfeberlin4 жыл бұрын
Guys, don't you see that stuff like this gets more and more complicated and thus less maintainable? Would you like to hunt for a bug in code like this? (Do you have experience doing this, especially if this isn't your own code originally?) One of the main goals in modern software development isn't the fanciest most optimized version of an algorithm but to have *readable* code. Code which the next maintainer will understand as fast as possible. It's alright to bring an algorithms from N log N down to N if you really have large input. If this is going to save 20 seconds of runtime within the next four years, it is probably not a good idea to even optimize for this. But any optimization beyond this (as in the post above) needs an enormously good reasoning to be justified. »This is even a little faster« is not such a good reasoning ;-)
@lucast22124 жыл бұрын
@@alfeberlin Then again, this is really easy to test, as you just have to compare its output to the sort(squared_arr) version on random arrays. So you could become pretty confident that the algorithm does what its supposed to do.
@alfeberlin4 жыл бұрын
@@lucast2212 Testability doesn't make the code clean ;-) You will find out the difference as soon as one of the tests fails ;-)
@gigelfranaru4 жыл бұрын
I'll take "what is compiler optimisation" for $0
@bencekovacs87264 жыл бұрын
@@alfeberlin Honestly, if you want readable code you only do sorting by hand if it is absolutely a must for performance. I'd just .stream().map(...).sorted().collect it. if i really wanted to make it performant, i would do sth like this: Stream negatives = .stream().takeWhile(i < 0).map(...) then Stream positives = .stream().reversed().takeWhile(i >= 0).map(...) and use something like negatives.mergeSorted(positives).reversed() and there you go, 3 lines of code, and even newbies can understand it. Google's coding challenges are stupid, it's much harder to model problems properly than to come up with fancy algorithms, and still they ask you to come up with algorithms that you can argue a lot about whether it's good or not.
@rafaelpernil4 жыл бұрын
My solution is finding the first positive value using binary search, splitting negative part from positive part, square both parts and merge them taking into account that the negative part is now "reversely sorted". Divide and conquer style!
@rafaelpernil4 жыл бұрын
My first thought was: Those negative values are the ones making this difficult, so let's get rid of them. And in the end, the worst-case complexity is still N (more precisely logn + 3N)
@ReTroIIer4 жыл бұрын
If you need a handy one-liner in java: int[] squaredArray(int[] array) { return Arrays.stream(array).map(i -> i * i).sorted().toArray(); }
@narendrachowdary68944 жыл бұрын
Ikr
@MY-bc3qq4 жыл бұрын
Just one minor add on to the comparison, we can replace the call to Math.abs by adding the two numbers together and return right on positive/left on negative.
@codegirl20694 жыл бұрын
That's interesting. Is using Math.abs () not recommended when you want to consider the most optimal solution?
@MrHarbltron2 жыл бұрын
You could save a scrap or two of memory through destructuring by doing "int i = right" in the loop.
@PProgress4 жыл бұрын
4:07 Arrays.sort(square_the_array); Isn't this question too easy for something like facebook? idk
@tysonslace53854 жыл бұрын
dude , are you dumb somehow?
@grammarjew5694 жыл бұрын
The time complexity is nlogn....too high.Facebook wants less not the average soln
@MrKeksdoserl4 жыл бұрын
I would argue in favor of the square everything then sort it method. It is O(n * log(n)), which is not slow as you said. Also our n is less than 10000, so when this is not called in a hot loop millions of times readability wins over shaving of one log(n) of the time complexity.
@B00Mnation4 жыл бұрын
Great solution. I would also add that if all the input numbers are positive, this approach can be simplified and done in-place, thus reducing the space complexity to O(1). That’s because when they are all positive, you know squaring them will not change their sorted order. Simply check the first index of your input array, and if its value is positive, square all the numbers in-place. You could also do something similar to save space if all the input numbers are negative, since you know their squares will be in reverse sorted order.
@mrugankgadgil73683 жыл бұрын
Nick White - you really have an excellent thought process while dealing with problems.
@minhazulislam46824 жыл бұрын
I know coding very little, but enjoy problem solving videos. thanks Nick.
@niranjanshettymay3 жыл бұрын
last approach does not work for the input : { 4, -2, 0, 9, 3} -- output will be : 0,4,81,9,16
@Meloncholics3 жыл бұрын
The problem says that the input array is already sorted. The input you gave isn't.
@RobertLugg4 жыл бұрын
Likely better to square them all up front. That avoids the absolute value and array operations are usually faster. Good video. Thanks.
@StraightCrossing4 жыл бұрын
Is it really faster though? You would need to loop through the array twice.
@moai8344 жыл бұрын
@@StraightCrossing you can do it as you compare them
@MY-bc3qq4 жыл бұрын
Niko Ursol If we are really nailing it to that detail, you’ll square each number twice by the way you describe. Better just compare the sum of two numbers with zero to get the optimal solution timewise.
@moai8344 жыл бұрын
@@MY-bc3qq why would you have to square it twice? It's only one time thing - before you comparing them, and than just merge stuff together as you go. You have to copy each int twice tho, but its cheap. (by copy twice i mean copy in buff to square them, and then emplace (copy again to resulting list) in the end even squaring whole list, grouping them together, reversing one half, merging them would be in O(n)
@jakepyrett17154 жыл бұрын
Yeah. You are making potentially millions of calls to ABS(). That's expensive
@jesusberrio5682 Жыл бұрын
If you order the list using absolute values, yo have the right order, example: [-6, -4, 1, 2, 3, 4, 5] => [1, 2, 3, 4, 5, 6] => [1, 4, 9, 16, 25, 36] it takes o(n)
@michaeldang81894 жыл бұрын
After hearing the question, I was like loop through and square, are you serious? You call that a coding interview, blah blah blah, then 2 minutes in... oh
@dragon_warrior_4 жыл бұрын
I was I can do this in less than 5 lines in python but this vid has almost 13 mins
@davideareias78764 жыл бұрын
@@dragon_warrior_ yes hes doing on java, phyton is to ez
@mattop86564 жыл бұрын
Yep wtf
@baka_geddy4 жыл бұрын
Atleast we can take the absolute value of the elements and sort it and then get the output... Edit: I did not watch this video fully...
@michaeldang81894 жыл бұрын
@@baka_geddy Sure that works, however the goal of the video is to bring it to linear runtime, i.e., no direct sorting.
@androidking81583 жыл бұрын
I came up with this before watching your solution: def squared_sorted_array(l): l=[abs(x) for x in l] n=len(l) o=[0]*n for i in range(n): o[i]=min(l) del l[l.index(min(l))] l=[x**2 for x in o] return l But, initially I thought of the same process that you used, but I thought it might be messy so discarded that.
@nikhilreddy64763 жыл бұрын
Oh, I thought to start pointers from middle where sign changes. Great solution.
@BharatiSubramanian992174 жыл бұрын
Man! You are gold. Thankyou so much for making these videos
@MrMadwyn2 жыл бұрын
Loop from the number closest to zero, compare it to the neighbours with their absolute values, square the larger one and put it in the result array.
@kristenkrofchik79983 жыл бұрын
Your teaching style really clicks for me! Thank you!
@phucminhnguyen89094 жыл бұрын
First i think about using hashtable so the time O(n) but it is not optimal way for memory. Your solution is so great.
@Moses_coder Жыл бұрын
Good work, using right and left pointer is the best way to go about it. May be only way!!
@addielmartinez9120 Жыл бұрын
Very well explained with a high quality microphone lol. Thanks!
@gothams11954 жыл бұрын
I find this similar to merge sort while we try to merge 2 list into 1. nice video man.....
@holatechm2 жыл бұрын
in 2nd approach if we use while loop instead for loop will improve time complexity @Nick
@sarveshmishra84163 жыл бұрын
This is the best explanation of this problem over the internet !!!
@mohammedjawahri57264 жыл бұрын
What if you go through the list, if you see a negative int, square it and throw it in a max heap (or max priority queue, or I'm assuming a normal queue would work also since array is sorted so negative ints thrown into the queue will be smallest square at the back biggest square at the front), If you see a positive int then square it? check max heap and keep popping until max element is less than your positive int, then just keep going, throwing elements in whatever new list you initialized at the beginning Should be O(n) if I'm not missing anything
@eversnipestudio3 жыл бұрын
Dude keep making these kind of videos, it helped so many people. God bless
@taggy91172 жыл бұрын
This is so easy in javascript with the sort command. You just sort the array and then use the forEach command to get the output.
@ZainAli-lk7pi3 жыл бұрын
What Nick is doing has time complexity O(n)/linear and he said it's the best way to do it, what if we square numbers of array and then apply MERGE SORT that has time complexity O(nlog(n)) in all the best to worst case time complexity scenarios (we would need left and right(start and end) values in array for merge sort). Which one would be good way to solve the problem please tell me, I'm confused? P.S. Nick's solution and mindset towards problem was absolutely amazing! :)
@fawazsullia56203 жыл бұрын
Your videos help me have the proper problem solving mindset. Thank you!
@anirbansarkar63063 жыл бұрын
The solution seems so easy once you explain it in your style. Thanks a lot for coming of with such great contents.
@Chickenspoon4104 жыл бұрын
Is there ever a case where you would need to have math.abs for the right pointer as well. Such as, if there are more negative numbers than positive and the right pointer hits a negative.
@vanamutt433 жыл бұрын
what about looping through the input array and adding the square of each number to a treeset?
@hawsh30664 жыл бұрын
you was 18k sub like a day ago ,I blinked and now you're 21.4K looks like somebody discovered the youtube algorithm secrete!!!! gj keep it up:)
@gangeshshaw1724 жыл бұрын
We can also make 2 vectors with squared value of - ve and +ve no.s and mergesort them
@dev10shah4 жыл бұрын
Can you tell which screen recorder you use?
@Yarin58794 жыл бұрын
Your last method are basically kind of merge two sorted arrays were you handle the minus value as their abs value
@vadimkokielov21734 жыл бұрын
just to be clear: + before the last step the indices are always equal (because the total number of processed elements is len(array) - 1 + hence it doesn't really matter for the last step which index is advanced; + if all elements are negative, the left pointer always advances because the absolute value of a negative is greater than any negative number (including the first) + if all elements are positive, the right pointer always advances because the left pointer points to the element with the smallest absolute value + the same reasoning applies when the negatives run out before the positives vs the positives run out before the negatives + if the order is negative, positive, negative, positive... or positive, negative, positive, negative -- then the two pointers meet in the middle, and which pointer advances last depends on the parity of the length and which element came first + elements with equal absolute values are treated as elements from the "right" side (they fall in the else clause)
@vadimkokielov21734 жыл бұрын
@Nick White it may have been more intuitive (though that's debatable) to condition the loop on equality of the indices and then just take the final element. But this is OK too, because on each loop step each index is changed by one, so the sum of the distances traveled by each index equals the number of iterations.
@jpchato4 жыл бұрын
Thank you, still learning how to code but I was able to follow along with your explanation 👍
@omarghosn86554 жыл бұрын
I ended up checking if they were equal (having a -12 and a +12) so I had an extra conditional statement but checking the absolute value of the left value to the right value is actually kind of elegant...didnt dawn on me to do that
@SidsVlog4 жыл бұрын
this solution is far better than your previous solution of the same problem. I guess you did that for leetcode. thanks for your work.
@lets_see_7774 жыл бұрын
i thought of travelling to 1st positive number and then use 2 pointers on right and left list just like in video, but i guess that travelling is unnecessary now
@placementexp19983 жыл бұрын
If we use the 'Set' data type the output would be sorted right? Isn't that O(n) complexity? The rest part of the code is the same.
@IvanRandomDude4 жыл бұрын
Nick: Simple idea is to square the array then sort it, but it isn't efficient because sorting is n*log(n) at best, we are aiming for linear time complexity Every other python "expert" in the comments: lemme write one liner to show how smart I am using built in sort method
@vatsrahul4 жыл бұрын
Don't we need Math.abs on array right if all the values in array are negative ? Like if the array is-6, -7, -8, -9, -10
@vrdash4 жыл бұрын
Dude, I also thought that but #Nick White saw the subtlety. First, the array you provided is not sorted. It should be [-10, -9, -8, -7, -6]. If you think carefully, since the array is sorted in the negative side too, you don't need Math.abs on the right part in any case
@kennethmensah44804 жыл бұрын
If you compare the squares rather than the abs you don't need to worry about that.
@FabsterMaster4 жыл бұрын
There's a small typo for the output at 5:12
@lucast22124 жыл бұрын
You said sorting is worst case O(NlogN). But its worst case is O(N^2) right? And just the average sort time for a random array is O(NlogN)?
@mueez.mp43 жыл бұрын
Been out of touch with problem solving for a while now. Being able to solve this optimally made me good about myself. Idk why I'm writing this....
@bhushanmaghade62982 жыл бұрын
What will be the time complexity of the solution algorithm given by Nick??
@bhaskargarai83714 жыл бұрын
Though it is not written here,I have to assume that optimal time complexity is what the interviewers are seeking??/And should I think about optiimizing my time complexity or spae complexity,when nothing about them are written here???
@anuragsandhu95904 жыл бұрын
In Javascript: function double(ar) { let arr = []; let pointer1 = 0; let pointer2 = ar.length - 1; for (let index = 0; index < ar.length; index++) { if (Math.abs(ar[pointer1]) > Math.abs(ar[pointer2])) { arr.unshift(ar[pointer1] * ar[pointer1]); pointer1++; } else { arr.unshift(ar[pointer2] * ar[pointer2]); pointer2--; } } return arr; }
@fredhair4 жыл бұрын
Theres a similar way still linear (2n tops) that I believe in real world could be faster on a large data set with all or mostly positive / negative inputs. If you can first find if/where the first positive or negative meets you could possibly perform some optimisations. So you're still comparing iterators but instead of working inwards from each end you work outwards from the midpoint. The solution in video is definitely better for general cases but if you know roughly what your inputs are like you can usually make optimisations. I believe this is something you learn with real world experience as 2 linear solutions can have vastly different runtimes.. this is one thing i dont like about these kind of questions.. yes it demonstrates knowledge and understanding of algorithms and datasets but in actual coding the problems are rarely like this and some calculation in a linear solution can work out slower than a n log n solution (its unlikely but possible). Profiling should always be preferred to simply relying on your time or data complexity.
@brianreynolds52544 жыл бұрын
You could make this greedier by adding a break condition to the for loop if the left item is positive. After that, you know everything else is sorted and can just splice it from the original array to the squared.
@I_amshobhit3 жыл бұрын
can i use sort function of python to sort it after squaring every element.. i think it's time will be O(n)..??
@mgf12343 жыл бұрын
solution doesn't work for all negative numbers - you need to do abs of right hand side too , and left and right pointers cross each other as there's no check for them "meeting"
@tartarus13224 жыл бұрын
Before the video: I’d use another array and I would go through the original array, square the element and use a binary search to find the location that the element should go and then place it: insertion sort. Edit: didn’t realize the original array would be sorted
@codingintelligenceci70813 жыл бұрын
I find your videos so easy to understand
@saeedbaig42494 жыл бұрын
"...yyyoooOOOOOOOOOOOOO (slap) what is up uhh (forgot the word for "coders") coding people that, watch coding videos" lmao I always love your intros
@foadhijab77884 жыл бұрын
is there a way to achieve time complexity of O(n) without using extra space (without initialising the output array and keeping the space complexity at O(1))?
@bokonon884 жыл бұрын
Yeah. Just loop through the array and find the first position (i) where a[i] < 0 and a[i+1] >= 0. The i'th position will be where the negative and the positive numbers split. Then keep one pointer at i and another at i+1. Compare absolute values at those indices, output the bigger number's square. Then just expand the pointers outward. (Nick started from the borders and made the pointers go inwards, we're doing the opposite). This keeps time complexity at O(n). Worst case is O(2n) when the whole array is negative. Keeps space complexity to O(1) (we're just using two pointers).
@bogdyee4 жыл бұрын
@@bokonon88 read the problem, you should not output elements one by one, you should return a full sorted buffer, so no, this solution doesen't work.
@mrolivernone40403 жыл бұрын
def solution(lst): if not lst: return "Invalid Input" return sorted(map(lambda x: x**2, lst)) lista = [-7, -3, -1, 4, 8, 12] print(solution(lista))
@n0ame1u13 жыл бұрын
Is there any way to improve the space complexity? Is it possible to do an in-place merge?
@Vaaaaadim4 жыл бұрын
It was not clear at the start 0:37 that the input array would be sorted. Were someone to stop and think about the problem at their own before you showed clarifying details at 1:15, they might waste some time. (In my case I gave it a few seconds of thought and just said ok, how is this a difficult problem, just square the values in place and then sort the array).
@mkedzier1234 жыл бұрын
Solution with reading values from both ends and comparing them is pretty obvious here.
@manmeetsingh87274 жыл бұрын
def sortedSquared(arr: [int]) -> [int]: squared = list(map(lambda x: x*x, arr)) for i in range(len(squared)-1): mini = i for j in range(i+1, len(squared)): if squared[j] < squared[mini]: mini = j t = squared[mini] squared[mini] = squared[i] squared[i] = t return squared
@robertfisher35074 жыл бұрын
absolute value of negative elements of input array and sort that array. then all you have to do is square each value in the same order.
@harshitjain82354 жыл бұрын
Would love to watch more of such solutions to interview questions