TABLE OF CONTENT
- CHATGPT, How does this affect interviews?
- Should I still learn Data structures and Algorithms?
- Blind 75, š¤ actually Blind 76
CHATGPT, How does this affect interviews?
Let's be honest, the only reason most self taught developers ever considered learning Data structures and Algorithms was for interview preparations.
Well the game has changed. CHATGPT is here š.
Yes, it is true that these days we really do not need to take the extra effort like before to learn how to solve certain algorithm questions, because CHATGPT can do that for us and even give us some comprehensive explanation on the solution.
Does that mean it can do everything for us?
š š At least not yet.
You see, solving algorithms was a vital part of a lot of company's interview process, but now that we have Artificial Intelligence, what then happens to this process? Because, unless it's a live interview and you specifically instruct a developer not to use the AI, any smart developer should definitely use it. š¤·š½
Whatever the case may be, some things stand out when solving algorithms
-
Can you solve the problem in psuedo code(i.e just explain the solution to someone without even writing code)?
-
If some parameters and constraints are changed, would you be able to alter the solution to suit the new constraints?
-
Can you think of a better solution that would be better optimized?
-
Do you really understand why that solution works?
In all this, just always remember that Artificial Intelligence (i.e CHATGPT in this case), is simply there to assist, and it's not every time it can answer all these questions accurately for you.
Should I still learn Data structures and Algorithms?
I have thought about this question and also have been asked by a couple of people, since we now have Artifical Intelligence to solve problems.
To think that data structures and algorithms are just for the sake of interviews and not to think of their practical application is to do great injustice to oneself
For programming languages will rise and fall, will come and go, but Data structures and Algorithms are everlasting.
This is because Data structures and Algorithms focus on two things which would forever remain constant in the programming world:
- Time complexity - How fast is this going to execute ?
- Space complexity - How much space is this execution going to take up ?
This is never going to change. If you build something small that is going to be used by very few people, you might not necessarily need to take into account these two. But if you build something you expect to be big and used by millions of people, be rest assured that you need to take into account these two.
Time complexity (How to manage time/speed)
Take for example:
const arrayIdStore = [
{id: '111', name: 'first'},
{id: '222', name: 'second'},
{id: '333', name: 'third'},
{id: '444', name: 'fourth'}
{id: '555', name: 'fifth'}
]
const found = arrayIdStore.find(item => item.id === '111') // O(n)
const arrayObjectStore = {
'111': {id: '111', name: 'first'},
'222': {id: '222', name: 'second'},
'333': {id: '333', name: 'third'},
'444': {id: '444', name: 'fourth'}
'555': {id: '555', name: 'fifth'}
}
const found2 = arrayObjectStore['111'] // O(1)
In the above code snippet, let's assume that you are required to get the data that has an id of 111
.
If your storage is an array, then you most likely might need to search through the entire array list before you can find what you are looking, if the object with id 111
is placed at the end of the array.
If your storage is an object, you can simply get it once, without having to search through the entire object storage, irrespective of whether it is the first item or last item in the storage
This is what is called TIME COMPLEXITY.
For in the array storage method, the time to find an item increases as the number of items in the array increases. While in the object storage method, the time to find an item remains constant irrespective of the object size.
Space complexity (How to manage space/memory)
Let's consider these two methods of solving the famous fibonacci sequence:
//-----------------------
// METHOD 1
//-----------------------
function fib(n){
const store = [];
store[0] = 0;
store[1] = 1;
for(let i = 2; i <= n; i++){
store[i] = store[i-1] + store[i-2]
}
return store[n]
}
fib(10) //55
//-----------------------
// METHOD 2
//-----------------------
function fib2(n){
let v1 = 0;
let v2 = 1;
for(let i = 1; i < n; i++){
let temp = v2;
v2 = v1 + v2:
v1 = temp;
}
return v2
}
fib2(10) //55
Even though both are valid solutions, method 1 is going to take up more of the computers storage than method 2.
This is because as the value n
, which is our input grows, the length of our store
variable increases. This is called O(n)
"linear" space complexity
While as for method 2, no matter how big n
gets we would always be able to solve the problem with just two variables v1
and v2
.
This is called O(1)
"constant" space complexity
You can see how this would affect our programme if we don't understand how time and space complexity work.
Blind 75, actually Blind 76
C'mon, of all the words to give this list they chose "BLIND" š. I have always wondered why.
Day in day out, we see new algorithm questions being created. Like how many LEETCODE, Hackerrank, Coding Game, e.t.c problems can you really solve? and what is the best approach to take in your study?
Then comes BLIND 75, I think it should be BLIND 76 though š check the list and see why I call it Blind 76
I don't know who made the list, but it sure has gained a lot of traction and after going through it, I see why. There is a certain level of progression about it and it covers most of the concepts one needs to really understand how to solve any question.
While going through the list I mainly made use of these Youtube channels:
Although none of the videos in these channels solved the algorithms in Javascript, the explanations were too good, that I was always able to come up with the corresponsing Javascript solution of my own
So without further ado, here is a link to the repository:
Feel free, to create a Pull request for anything that you feel could be improved or any question not yet solved, would appreciate it š.
In all, I think we should learn Data Structrues and Algorithms, because in the long run it would definitely make one a better developer.
Cheers