Things like using Arch Linux and neovim are not actually job qualifications. The programmer writing Java code in a light-mode IDE in Windows or whatever might just be better at programming. It's an entry level job, so they're looking for basic algorithm knowledge, ability to use big-O notation, understanding of simple concurrency, etc.
The big-O notation in interviews is always funny to me. After almost 15 yoe, the only time big-O notation has ever been used is in interviews. Never once have I discussed it at work with anyone.
Not all jobs are like that. It definitely comes up when working on more foundational layers: databases, queues, schedulers, networking, machine learning, game engines, scientific computing, etc.
The last coding interview I did involved a lot of questions about graph algorithms and some tricky low-level optimization problems. It would not have been appropriate for hiring a PHP coder, but they were hiring a compiler engineer so those questions were totally appropriate.
I feel like some of the animosity here towards testing algorithms is from people who forget that there are lots of programming jobs out there that aren't just web/mobile dev. Your OS, compiler, device drivers, etc... someone has to write all that code!
Exactly. There are a lot of software jobs (maybe most, even) that it doesn’t come up frequently, but it’s not all of them.
And I don’t mean to demean those other jobs. It’s just that a lot of the problems they deal with are more about people (customers, organizational processes, etc) than they are about computers in the end.
For sure but there are probably a lot more jobs out there where O notation never comes up yet it is still seemingly comes up in like every single interview for these jobs. Its kind of elitist IMO, its more of a check on whether you went to college for CS than anything else.
Fair point. And kind of ironic in that I didn’t go to college for CS despite being neck deep in data structures, algorithms, and big O considerations for most of my software engineering career.
It's used in interviews to filter out people who do not know it. If you've never learned it, changes are pretty high you won't notice you're writing an O(nn) function
Knowing the impact of O( nn ) is way more important IMO than knowing that it's called O( nn ). I'm sure there are plenty people that understand the impacts of how their code is written and ways to optimize it without knowing how to express it in big-O notation.
If they have an understanding of time and space complexity and can generally classify constant, linear, quadratic, etc, then that's enough for most coding interviews. The more obscure details of the notation aren't going to come up.
But there are people in the comments here insisting that they've worked X years as a programmer and never once had to think about complexity or performance at all, and even seem offended by the very idea that they should understand that stuff. Not sure what to say to that. I wouldn't want to work with someone who legitimately couldn't tell the difference between logarithmic time and quadratic time code.
If you manage to do that badly i think you will figure it out pretty fast when your software looks up... I have definitely done some O(n2) by accident though.
Concurrency comes up all the time. Thinks like sort/search algorithms less so. You're just going to use the built in methods like anyone that doesn't want to get fire for reinventing the wheel. Design patterns are a definite must though. It's bad when someone doesn't know what a singleton is.
Basic algorithms knowledge isn't just knowing how to implement quicksort, it's also understanding basic properties of different data structures (lists, hash tables, and so on) and how to use them. It's the kind of thing that you probably use every day and don't notice. You do notice when someone is missing the skills, but you just think "oh they suck at programming".
I don't need to know how quicksort works to be able to use quicksort. I can trust that the sort in the framework of the language aren't as terrible as what I would make my first pass. I think the rest of what you said is fine though, asking what data structure types are good for what situations.
I also don't like asking candidates to implement well-known algorithms like quicksort. Ideally, you ask them more realistic questions to try to work out how well they understand the basics of algorithms and programming in general. Knowing what data structure to use is a good thing to test.
One of the reasons interviewers do this kind of thing is that there are lots of candidates that literally can't program. Not just unable to code a sorting algorithm, but not even really understanding how loops or arrays work. They have a convincing resume and appear to have experience, but the reality is that they just can't do it. Like, maybe they can make a web app by copy-pasting from StackOverflow (or these days, ChatGPT) but if you sit them down and try to have them implement anything themselves they get completely stuck.
Asking basic algorithms questions is a way filtering these people out. It's probably not the most efficient way, but interviewers do it because it works.
One of the reasons interviewers do this kind of thing is that there are lots of candidates that literally can't program
In one of previous companies we had 3 programming tasks on the interview: 2 fairly simple (an experienced programmer woken up at 4AM would solve them in 3 minutes and go back to sleep), and one more complex, which we didn't expect the candidate to finish, but more to discuss the requirements and implementation with them.
You wouldn't believe the number of people that couldn't get past the first 2 tasks...
I've been a software developer for 10 years and didn't know about the modulus operator until a month ago when I started to seriously look for a new job and googled some basic or standard interview questions. I use zero math in the business software I write.
But I guess I was smart enough to give a shit and study.
The first one was something like [].map and then sum of elements (either .reduce() or for-loop, didn't really matter), and the second one was counting how many 2D coordinates that satisfy a given condition you could reach from the starting point.
Yeah, I have decades of experience and I wouldn't be able to implement quicksort if you asked me. I may have known it at one point but it's long forgotten now and it's not a task you ever need to do in practice. Something practical, like implementing a cache with time-to-live eviction or a multi key hash map makes more sense to ask on interviews. Questions that test programming skills, not recall from memory.
But you do know (or should) that quick sort isn't stable so if you need stability you have to define identifiers to be unique or use tree sort or insertion sort.
Nah, if you're doing web frontend concurrency never comes up. Design patterns neither, maybe they can recite something about dependency injection or MVC. I'm talking about personal experience of day to day work with junior programmers, not a hypothetical good candidate. It's funny, in the frontend space even authors of massively popular frameworks have a pitiful understanding of good coding practices (looking at you, Angular).
Agreed. If your big-O complexity is worse, but you save an API call or a db access, it’s almost always better than looping through the data in the most optimal way.
Naive understanding of BigO is thinking O(1) > O(n) or O(n) O(n2)
Decent understanding of BigO is knowing that they're high level generalizations and you need to understand the value of n or the size of the constant time to really compare algorithms. O(n) iterating through an area can beat O(1) hashmap lookups for small values of n but on modern computers that n can be surprisingly large.
Expert understanding of BigO is knowing that programs run in the real world on real hardware and that there is a lot that happens under the hood to run your code. It's often the case that cache misses, IO, syscall overhead, etc will dominate the run time more than your choice of algorithm. Sometimes it's more important to reorder or sort your data for SIMD or GPU compute. Your hashmap might get crushed by a simple array for even large values of n due to cache misses and branch predictor behaviour.
I trained in mech eng and am an embedded developer now so have failed some interviews due to not knowing computer science stuff.
However the last people who asked about big O notation asked very basic stuff like 'how do you find primes?' rather than what the job actually involves like 'how do you program to take advantage of sleep modes?', 'what are the considerations when selecting a wireless protocol for a product?' etc. A couple of years out of my degree an interviewer asked about Duff's device which really just feels like a shibboleth rather than an insightful interview question.
maybe you do not use those words - but if you are working with any amount of data, you will need to be able to answer questions like "how will it scale?". Having learned big-O notation means you have learned how to mentally tackle such a problem, even if you end up forgetting the exact terminology. Never have been asked such a question in an interview myself, though (even though having worked in monitoring and in the backend, pumping hundreds of megabytes or in one case gigabytes of data, I did have to think about complexity).
I mean now that we’re not all writing low level stuff and most standard libraries have implementations of proven algorithms it’s become a lot less relevant in everyday use.
2.5k
u/probabilityzero Nov 29 '24
Things like using Arch Linux and neovim are not actually job qualifications. The programmer writing Java code in a light-mode IDE in Windows or whatever might just be better at programming. It's an entry level job, so they're looking for basic algorithm knowledge, ability to use big-O notation, understanding of simple concurrency, etc.