How do we recruit software developers in an age where everybody studies for the interview?












43














As a recruiter, I find it increasingly hard to recruit good software developers, due to the fact that it has become very easy to simply study for a job interview by reading any of those 14020 job interview questions for the software developer! books that are immensely popular these days.



It's gotten to the point where you pretty much can't ask a question without the applicant already having pre-studied at least a version of that same task and hence knows, roughly, what the solution is.



Now, this would of course not be a problem if knowledge of those problems is what we are looking for ... except, that isn't what we are looking for. Nobody cares if you know how to apply quicksort to some contrived, made-up example. The point isn't that you know how to solve those problems, the point is that you can figure it out. It's problem-solvers that we want, not problem-memorizers.



Because, once you actually get the job, you'll most likely never run into any of those problems from the job interview book again, so it's not your ability to memorize their solutions that matters; it's your ability to come up with a solution on the spot that is valuable. And yet, that is no longer testable, due to all these memorizers that read interview questions over and over.



How do we fix this issue? Because I am frankly tired of hiring promising software developers who answer each question perfectly in job interview questions, and then when you actually see them code in a real-world situation, you realize how little they actually know.










share|improve this question









New contributor




Indu is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.
















  • 44




    Why not dispense with asking common algorithm questions?
    – rurp
    16 hours ago






  • 6




    Sorry, can you clarify whether you are working for a recruiting firm, or you are just making hiring decisions for your own company?
    – A C
    15 hours ago






  • 1




    Why are you as a recruiter concerned about this? Isn't your job to just gather candidates? I have never had to deal with any kind of recruiter that did a pre-screening for the company, that's usually left to people who know the tech. Aside from that, why is it a problem if a candidate studies for the interview? Doesn't that show motivation? Isn't an employee that is willing to study for an important meeting desirable?
    – kevin
    6 hours ago










  • In fact, most recruiters I've dealt with try to sell as many candidates to as many companies as possible regardless of matching profiles. Downsides of having commission based a-technicals trying to hook up companies and candidates.
    – kevin
    6 hours ago






  • 3




    Just wondering - where do you get your questions from? Might I suggest that if it's from "14020 job interview questions for the software developer" that your annoyance that candidates know the question might be on par with theirs?
    – UKMonkey
    4 hours ago
















43














As a recruiter, I find it increasingly hard to recruit good software developers, due to the fact that it has become very easy to simply study for a job interview by reading any of those 14020 job interview questions for the software developer! books that are immensely popular these days.



It's gotten to the point where you pretty much can't ask a question without the applicant already having pre-studied at least a version of that same task and hence knows, roughly, what the solution is.



Now, this would of course not be a problem if knowledge of those problems is what we are looking for ... except, that isn't what we are looking for. Nobody cares if you know how to apply quicksort to some contrived, made-up example. The point isn't that you know how to solve those problems, the point is that you can figure it out. It's problem-solvers that we want, not problem-memorizers.



Because, once you actually get the job, you'll most likely never run into any of those problems from the job interview book again, so it's not your ability to memorize their solutions that matters; it's your ability to come up with a solution on the spot that is valuable. And yet, that is no longer testable, due to all these memorizers that read interview questions over and over.



How do we fix this issue? Because I am frankly tired of hiring promising software developers who answer each question perfectly in job interview questions, and then when you actually see them code in a real-world situation, you realize how little they actually know.










share|improve this question









New contributor




Indu is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.
















  • 44




    Why not dispense with asking common algorithm questions?
    – rurp
    16 hours ago






  • 6




    Sorry, can you clarify whether you are working for a recruiting firm, or you are just making hiring decisions for your own company?
    – A C
    15 hours ago






  • 1




    Why are you as a recruiter concerned about this? Isn't your job to just gather candidates? I have never had to deal with any kind of recruiter that did a pre-screening for the company, that's usually left to people who know the tech. Aside from that, why is it a problem if a candidate studies for the interview? Doesn't that show motivation? Isn't an employee that is willing to study for an important meeting desirable?
    – kevin
    6 hours ago










  • In fact, most recruiters I've dealt with try to sell as many candidates to as many companies as possible regardless of matching profiles. Downsides of having commission based a-technicals trying to hook up companies and candidates.
    – kevin
    6 hours ago






  • 3




    Just wondering - where do you get your questions from? Might I suggest that if it's from "14020 job interview questions for the software developer" that your annoyance that candidates know the question might be on par with theirs?
    – UKMonkey
    4 hours ago














43












43








43


9





As a recruiter, I find it increasingly hard to recruit good software developers, due to the fact that it has become very easy to simply study for a job interview by reading any of those 14020 job interview questions for the software developer! books that are immensely popular these days.



It's gotten to the point where you pretty much can't ask a question without the applicant already having pre-studied at least a version of that same task and hence knows, roughly, what the solution is.



Now, this would of course not be a problem if knowledge of those problems is what we are looking for ... except, that isn't what we are looking for. Nobody cares if you know how to apply quicksort to some contrived, made-up example. The point isn't that you know how to solve those problems, the point is that you can figure it out. It's problem-solvers that we want, not problem-memorizers.



Because, once you actually get the job, you'll most likely never run into any of those problems from the job interview book again, so it's not your ability to memorize their solutions that matters; it's your ability to come up with a solution on the spot that is valuable. And yet, that is no longer testable, due to all these memorizers that read interview questions over and over.



How do we fix this issue? Because I am frankly tired of hiring promising software developers who answer each question perfectly in job interview questions, and then when you actually see them code in a real-world situation, you realize how little they actually know.










share|improve this question









New contributor




Indu is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.











As a recruiter, I find it increasingly hard to recruit good software developers, due to the fact that it has become very easy to simply study for a job interview by reading any of those 14020 job interview questions for the software developer! books that are immensely popular these days.



It's gotten to the point where you pretty much can't ask a question without the applicant already having pre-studied at least a version of that same task and hence knows, roughly, what the solution is.



Now, this would of course not be a problem if knowledge of those problems is what we are looking for ... except, that isn't what we are looking for. Nobody cares if you know how to apply quicksort to some contrived, made-up example. The point isn't that you know how to solve those problems, the point is that you can figure it out. It's problem-solvers that we want, not problem-memorizers.



Because, once you actually get the job, you'll most likely never run into any of those problems from the job interview book again, so it's not your ability to memorize their solutions that matters; it's your ability to come up with a solution on the spot that is valuable. And yet, that is no longer testable, due to all these memorizers that read interview questions over and over.



How do we fix this issue? Because I am frankly tired of hiring promising software developers who answer each question perfectly in job interview questions, and then when you actually see them code in a real-world situation, you realize how little they actually know.







software-industry recruitment






share|improve this question









New contributor




Indu is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.











share|improve this question









New contributor




Indu is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









share|improve this question




share|improve this question








edited 1 hour ago









Peter Mortensen

50547




50547






New contributor




Indu is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









asked 20 hours ago









Indu

22523




22523




New contributor




Indu is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.





New contributor





Indu is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.






Indu is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.








  • 44




    Why not dispense with asking common algorithm questions?
    – rurp
    16 hours ago






  • 6




    Sorry, can you clarify whether you are working for a recruiting firm, or you are just making hiring decisions for your own company?
    – A C
    15 hours ago






  • 1




    Why are you as a recruiter concerned about this? Isn't your job to just gather candidates? I have never had to deal with any kind of recruiter that did a pre-screening for the company, that's usually left to people who know the tech. Aside from that, why is it a problem if a candidate studies for the interview? Doesn't that show motivation? Isn't an employee that is willing to study for an important meeting desirable?
    – kevin
    6 hours ago










  • In fact, most recruiters I've dealt with try to sell as many candidates to as many companies as possible regardless of matching profiles. Downsides of having commission based a-technicals trying to hook up companies and candidates.
    – kevin
    6 hours ago






  • 3




    Just wondering - where do you get your questions from? Might I suggest that if it's from "14020 job interview questions for the software developer" that your annoyance that candidates know the question might be on par with theirs?
    – UKMonkey
    4 hours ago














  • 44




    Why not dispense with asking common algorithm questions?
    – rurp
    16 hours ago






  • 6




    Sorry, can you clarify whether you are working for a recruiting firm, or you are just making hiring decisions for your own company?
    – A C
    15 hours ago






  • 1




    Why are you as a recruiter concerned about this? Isn't your job to just gather candidates? I have never had to deal with any kind of recruiter that did a pre-screening for the company, that's usually left to people who know the tech. Aside from that, why is it a problem if a candidate studies for the interview? Doesn't that show motivation? Isn't an employee that is willing to study for an important meeting desirable?
    – kevin
    6 hours ago










  • In fact, most recruiters I've dealt with try to sell as many candidates to as many companies as possible regardless of matching profiles. Downsides of having commission based a-technicals trying to hook up companies and candidates.
    – kevin
    6 hours ago






  • 3




    Just wondering - where do you get your questions from? Might I suggest that if it's from "14020 job interview questions for the software developer" that your annoyance that candidates know the question might be on par with theirs?
    – UKMonkey
    4 hours ago








44




44




Why not dispense with asking common algorithm questions?
– rurp
16 hours ago




Why not dispense with asking common algorithm questions?
– rurp
16 hours ago




6




6




Sorry, can you clarify whether you are working for a recruiting firm, or you are just making hiring decisions for your own company?
– A C
15 hours ago




Sorry, can you clarify whether you are working for a recruiting firm, or you are just making hiring decisions for your own company?
– A C
15 hours ago




1




1




Why are you as a recruiter concerned about this? Isn't your job to just gather candidates? I have never had to deal with any kind of recruiter that did a pre-screening for the company, that's usually left to people who know the tech. Aside from that, why is it a problem if a candidate studies for the interview? Doesn't that show motivation? Isn't an employee that is willing to study for an important meeting desirable?
– kevin
6 hours ago




Why are you as a recruiter concerned about this? Isn't your job to just gather candidates? I have never had to deal with any kind of recruiter that did a pre-screening for the company, that's usually left to people who know the tech. Aside from that, why is it a problem if a candidate studies for the interview? Doesn't that show motivation? Isn't an employee that is willing to study for an important meeting desirable?
– kevin
6 hours ago












In fact, most recruiters I've dealt with try to sell as many candidates to as many companies as possible regardless of matching profiles. Downsides of having commission based a-technicals trying to hook up companies and candidates.
– kevin
6 hours ago




In fact, most recruiters I've dealt with try to sell as many candidates to as many companies as possible regardless of matching profiles. Downsides of having commission based a-technicals trying to hook up companies and candidates.
– kevin
6 hours ago




3




3




Just wondering - where do you get your questions from? Might I suggest that if it's from "14020 job interview questions for the software developer" that your annoyance that candidates know the question might be on par with theirs?
– UKMonkey
4 hours ago




Just wondering - where do you get your questions from? Might I suggest that if it's from "14020 job interview questions for the software developer" that your annoyance that candidates know the question might be on par with theirs?
– UKMonkey
4 hours ago










15 Answers
15






active

oldest

votes


















69














Provide the candidate with a genuine programming test in the interview - a laptop hooked up to a projector with a broken project, with a mixture of basic to complex bugs, and ask them to add some functionality, again ranging from basic to moderately complex. This is something nobody can really study for and will actually provide a showcase of their skills. Have technical people there talking to the candidate to get a feel for their personality and how they approach the problems faced.



For the job interview for my current role, I had spent 2 weeks studying programming principles, design patterns, database stuff etc. I was able to answer all the theoretical questions well and think I came across well



I was then handed a laptop which was connected up to the projector and shown a solution which contained a broken website with a defined number of errors which I had to debug and add some simple functionality. While I wasn't very familiar with the front-end framework used by the company, I was able to fix about half the bugs and then give my best guess as to what the causes were for the remaining bugs based on what I could see, and this was good enough to get me in the door.



The whole thing, between the theoretical questions and the website debugging session lasted about 2 hours.






share|improve this answer



















  • 30




    Note that this approach, while highly informative, requires a technically competent observer to rate the interviewee's work.
    – chrylis
    16 hours ago






  • 8




    @chrylis only a unicorn HR person would have the technical know-how to hire somebody without the need to having a technical person on hand. The issue is that the OP is saying that the technical tests questions they are asking have already been prepared for.
    – user1666620
    15 hours ago








  • 13




    @chrylis in that case they're morons and deserve every incompetent they get
    – user1666620
    15 hours ago






  • 15




    @chrylis Any approach will require a technically competent observer. There is simply no way in general for a non-technical person to judge programming ability, as far as I've been able to tell.
    – David Thornley
    15 hours ago






  • 25




    Be very obvious in the source code that this is all contrived source. You don’t want someone thinking you’re trying to get two hours of free labour out of them.
    – Ian MacDonald
    13 hours ago



















39















once you actually get the job, you'll most likely never run into any of those problems from the job interview book again




If their job doesn't involve solving those kinds of problems, why test them on them in the first place?



Why not give them a real problem they would encounter on the job instead?



That's my recommendation. Surely you will have many examples of real on-the-job problems to choose from to find a suitable one.






share|improve this answer








New contributor




Alexander O'Mara is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.


















  • This answer does not appear to differ significantly from user1666620's.
    – jpmc26
    9 hours ago






  • 2




    They are somewhat similar in suggested solution. I thought it was important to address why their current method isn't testing what they actually wanted though, and suggest that new tests could be as simple as using recent challenges programmers have faced, rather than inventing new contrived tests.
    – Alexander O'Mara
    9 hours ago










  • @jpmc26 I would say that this answer more clearly identifies the root of the problem. The OP is clearly asking the wrong questions. Sure, the final suggestion is more or less the same for both of these answers, but stopping to ask the OP "why are you asking your current questions?" is a very important addition.
    – Conor Mancone
    20 mins ago



















13















  • Have multiple interviewers. Your strongest engineers on the team should participate in the interview process - they definitely want to work with people better than the one's that are struggling, right? Let other engineers conduct their own 1 on 1 interview. And have another engineer do the initial phone screens.


  • Ask an open ended design question. for a problem of medium complexity. Ask the candidate to write out the header file, class declarations, box diagrams, etc... Does the candidate ask clarifying questions? After he's done with a basic design, introduce a new requirement that would break his design. Is he able to pivot? Pick one part of his design and probe deeper.



  • Ask a question that probes if they have a deep understanding of the platform fundamentals. Some examples I've asked.




    • "How does the C++ compiler implement virtual methods?"

    • "How do closures work in Javascript?"

    • "Explain when you would ever want to use UDP instead of TCP."

    • "After you type a www.foo.com into a browser address bar, tell me about all the network activity and protocols involved to get the content on the screen."



  • Probe for genuine interest in programming. "Tell me about a program you wrote for fun that wasn't for work or school." A good candidate will tell you about an app, website, or hack that he did for his own personal pleasure. A weaker candidate will only tell you about the program he wrote to figure something out for work/school.







share|improve this answer



















  • 23




    Probe for genuine interest in programming - theoretically good paragraph but... I have small kids and this is my priority when I'm not in the office + I spend 4 hours per day commuting to my current office location. I have no time for hobby other than watching maybe one movie per week, not to mention running an own project. It says nothing about my commitment at work nor about my skills.
    – ElmoVanKielmo
    15 hours ago










  • @ElmoVanKielmo interviewing criteria will reflect the interviewer's biases/preferences. For example, for any valuable skill/criterion X, you can argue "I know successful people that don't have X". But if the company is full of the type that know X, probably not going to be a good fit either way.
    – Chan-Ho Suh
    14 hours ago






  • 4




    "How does the C++ compiler implement virtual methods?" Which one? And what do you mean by "methods" since this isn't a standard term in C++? ;) (inb4 "thank you for coming, we'll let you know"; whoops)
    – Lightness Races in Orbit
    13 hours ago








  • 3




    Those are good sample questions and remind me of the questions I asked when interviewing in the past. We got good results thanks to this selection process. You'd be amazed (or not) at how many apparently qualified candidates can't talk you through the very basics of an HTTP request or the difference between TCP and UDP. And, yes, they'd claimed knowledge in those spheres.
    – Lightness Races in Orbit
    13 hours ago












  • Having all your other engineers come in rarely achieves anything concrete. Everyone ends up just talking and batting stuff around. If you do want to try that approach, its better that the other engineers think out and write down a difficult question.
    – Fattie
    7 hours ago





















7














I've been most of my life as an electrical engineer, and back in the 90s many of the companies I'd interview with stopped asking me questions about electrical engineering. Between my schooling and my work resume, it was obvious to them that I knew enough about electrical engineering to meet their needs. What did they ask about?



My personality. My ability to work in (and lead) a team. My cross-discipline skills. My capacity to learn.



To be ruthlessly blunt, engineering skills (especially programming skills) are a dime a dozen. There are so many basically competent people out there that there is nothing about programming or engineering that's worth asking (unless you're interviewing a new graduate with no internship experience).



What's important is being sure the candidate is suitable for your environment. How well will they work with the existing personalities in your company? Do they bring more to the table than the skills needed for the basic job? How quickly can they come up to speed with changes in company direction? technology? or design standards? Are they willing to work beyond the basic job, providing (e.g.) scholarly articles, conference presentaions, patents, and other "bring honor to the company" activities? And can they show that they can do any of this?



I can sum this up with a comment I made to Philips Semiconductor recruiters long ago (as an employee). I can teach a 10-year-old to connect the dots when it comes to microelectronic design. Teaching them WHY you connect those dots is another matter. Therefore, you can't judge a new employee by how well they connect the dots. You have to find ways to discover how well they know WHY they're doing what they're doing. That's where teamwork and extra-curricular activities come in. They show depth of understanding.






share|improve this answer








New contributor




JBH is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.














  • 11




    "There are so many basically competent people out there that there is nothing about programming or engineering that's worth asking (unless you're interviewing a new graduate with no internship experience)." I don't agree. I've had a bunch of people in for interview who looked great on paper but couldn't answer even some pretty basic questions about fundamental commonplace technologies. We didn't even get as far as fit, though that is of course also important. I'm happy to hear that you were qualified for the roles you applied for, but this is definitely not the case for all candidates.
    – Lightness Races in Orbit
    13 hours ago






  • 1




    Right, this is not the case with software. Almost all "programmers" are barely competent, have a self-taught hobbyist vibe, and can't actually do anything. The OP is perfectly correct that folks drill to answer "interview type questions" you can look up online. The QA is about how to solve this problem.
    – Fattie
    7 hours ago










  • And if you need highly competent people there are not as many as there are needed.
    – Thorbjørn Ravn Andersen
    35 mins ago



















6














Use Whiteboard interviews, and ask problems which are related to the skills and business domain that you're interested in. Look for people that you can work with, even if they aren't perfect matches for the position, because you can always train the right person if they have potential. Ask existing employees for recommendations (and offer a finders-fee)






share|improve this answer

















  • 4




    Pete, I fear that OP is indeed talking about whiteboard-type problems!
    – Fattie
    20 hours ago






  • 3




    @Fattie - Yep - but a good thing with whiteboard interviews rather than take-away coding tests is that you can change the parameters halfway through the question to throw a spanner in the works
    – PeteCon
    20 hours ago






  • 8




    Don't ask people to code on a whiteboard! That's cruel!
    – Lightness Races in Orbit
    14 hours ago






  • 2




    These whiteboards interview are exactly the thing that got lots of books printed to go through them. As a developer, I like spending my time into actually learning my job and executing it, but my job is not writing programs on a whiteboard.
    – Pac0
    13 hours ago








  • 1




    @LightnessRacesinOrbit I disagree. Now, demanding that the code they write on the whiteboard compiles, that would be cruel. But writing some pseudo code is, IMO, a good way to get an impression of the coding abilities of a candidate, given the limited amount of time you have during an interview.
    – Abigail
    3 hours ago



















5














After getting through enough basic questions to show that they have some minimal (by my needs) ability to write code, I move on to the tougher part of the interview, based on two subject areas, their work and my work.



Ask for information about a recent project at their current job. Even with respect to NDAs and IP restrictions, they should be able to explain the business problem, the complexity of the problems and how they overcame them. If they can't explain their own work to me so that I can understand and evaluate, then I worry about how successful they will be.



Ask them to white board a design/solution to one of your current problems. The expectation should not be a working solution but how they approach the problem. Provide enough information that they have a high level scope for the problem. They should ask good questions, and you should provide good answers so they can proceed. They should be able to sketch out some sort of solution. In the end their solution may not work out, but you will be able to see how they work on a problem and whether or not they should be able to work on the projects you will have.






share|improve this answer





























    4














    About a year ago I started to have discussions with candidates. There are many topics that are controversial in the industry – for example:




    • What framework is the best?

    • Is a certain design pattern actually useful?

    • Focus on new features or fix bugs first?


    First I ask the candidates about their opinion. Once they got their point across I simply pick the opposite and argue against it. The following discussion will tell me a lot.




    • Did they only memorize some facts for the interview or do they actually have experience with this area and good examples to prove their point? Actually, I was very surprised by how often their argument is: because I always did it that way

    • How well are they able to bring their arguments and the complex technical details across? Are they good in teaching?

    • How do they handle resistance? Do they try to convince, do they try to please or do they start to be aggressive or arrogant? Are they open to learning?


    I am aware that this might be very stressful for the candidate. Therefore the has to be done very carefully.






    share|improve this answer





























      3














      Simply. You just grill the applicants on the implementation details and change requirements on them to see how they respond. Make them use what they've memorized as building blocks.



      To be frank, problem memorizing isn't an issue. Memorization is actually one of the key techniques chess players use to learn the game. By memorizing algorithms your applicants are developing a library of solutions from which to work from. This means that they'll be able to solve problems better in the future, if the patterns and implementation of the patterns they're learning are actually useful.



      What you need to test is that last part. By varying the problem in real time you get to see how well the applicant actually understands how to use what they've memorized. This means that you can ask them about better ways to solve the question and you can even ask them to compose their solution into a work flow to do something completely different.



      What you want is someone who can solve problems. What you don't want is someone who solves problems the way you want to see them solved. If everyone's memorizing solutions, all you need to do is test their ability to use what they've memorized. When it comes down to it, everyone uses what they know to break down what they don't know. If your devs can use patterns they've already mastered to break down problems of increasing complexity, then they would have been able to reverse a linked list if they've never seen anyone do it before.



      As a recruiter, this is as far as you can reasonably be expected to go without trying to get free labor out of your applicants.






      share|improve this answer





















      • It's funny you mention reversing a linked list. I expect that's the type of question OP is complaining about. Personally, I go even more basic than that. I ask what data structures they have used in their favorite language, e.g. in Python, there is a list and a deque. I would ask about differing performance characteristics between them for operations . They may have this memorized but not understand that a list is backed by an array whereas a deque is backed by a linked list. So despite their ability to reverse a linked list, they don't really understand why you use linked lists.
        – Chan-Ho Suh
        14 hours ago



















      2














      In some ways, studying for the interview is a good thing. You probably already ask that people study about four years in a University to prepare for the interview.



      Now, if your interviewing process is scripted, and the script lacks any kind of variation, then it is just a matter of time before the answers become memorized in the population. Solutions include:




      1. As questions that are generated, with variable fields that require the work to be done specific to this asking of the question.

      2. Change the question set from time to time, to minimize the time to build the pool of answers.

      3. Change the entire approach, giving them a trivial project with specifically added bugs, asking them to fix it and add a known feature.


      Also, consider the problem in the larger sense, if you are asking for information in an interview, and the information was memorized, then that should be an ideal candidate, unless you are asking for the wrong information.



      You are deciding that the information isn't what is wanted, so you might be able to fix the problem by asking for the right kind of information.






      share|improve this answer





























        2














        I believe you misunderstand the reason why big companies ask algorithm questions. Writing out the algorithm for quicksort is probably not a very useful skill for the majority of developers. Likewise figuring out the best way to parse a 1 million character string is not something people routinely do at work. However knowing how to solve these problems is a great way of filtering out the dumb candidates. If someone is too dumb for the job, they won't be able to coherently answer any of the interviewing puzzles commonly asked at job interviews. Even if they memorize all the answers, you could easily break their pattern by asking a slightly different variation of the question or adding a bonus question on the spot. In contrast, a good candidate would have no issues preparing for the "test" and would pass with flying colors.



        Interviewing is about filtering out the bad candidates, rather than about finding the best candidates per se. There's no harm in having someone prepare in advance, as this wouldn't help someone who's not prepared to work on the right level.






        share|improve this answer





















        • This is quite true. "interview tech questions" are just a filter. (like having "a reasonably professional CV" is a filter.)
          – Fattie
          7 hours ago



















        1














        If your candidates are able to pass your interviews by studying, isn't that a strong indication of their ability to study and learn? If you're hiring fresh grads, that's really the most valuable skill to hire for.



        If an experienced candidate is doing it, at the very minimum it means they're highly motivated to study for your interview. Which means they're strongly interested in coming to work for your company. And also, it's a strong signal that they haven't lost their ability to learn and grind after leaving college. You should still ask them questions about their work experience, achievements, and collaborations with co-workers to get a better sense of their overall ability.




        It's problem-solvers that we want, not problem-memorizers.




        Very few people can come up with quicksort, or Floyd's cycle detection algorithm, or finding the longest increasing subsequence in the timespan of an interview having never studied the solution. Those who can are unlikely to be interviewing at your company for regular dev jobs. No offense, I'm sure it's a great company, but statistically most of your candidates are not going to be of that caliber - because very few programmers in the world are.



        On the other hand, if your candidates are able to apply solutions to problems they've seen before to variations of that problem or to related problems, it's a signal that they're good at pattern-matching and identifying what type of problem they're looking at. Conversely, if they've never seen that type of problem before you also have signal that they know how to research a solution and understand it - because after all, they studied for, and passed your interview.






        share|improve this answer

















        • 1




          The thing is, you shouldn't have a test that can be aced by memorizing what can be quickly looked up, because such memorization is not a useful job skill. Rather, you should have a test/question that requires the kinds of thinking necessary on the job that a search engine can't help with, or at least requires using it in a clever and inventive way.
          – Chris Stratton
          9 hours ago





















        1














        Being able to come up with a solution on the spot isn't really that great a qualification, either, at least IMHO. I've certainly come up with a lot of on-the-spot solutions that in retrospect weren't all that great, and have sometimes spent weeks or months finding a decent solution to a really hard problem. (And sometimes the solution is just remembering that I saw something similar in a code example somewhere...)



        You don't say whether you're trying to hire new grads or experienced developers, but in either case I think you really have to find some way to look at what they've done previously. Sometimes it's looking at published papers (even if the person isn't the principal author), sometimes it's a personal recommendation, sometimes just asking them to show you something they've done that they're proud of. FWIW, I don't think I've ever gotten a job that I interviewed for that didn't have at least one of those things going for it.






        share|improve this answer





























          1














          As an applicant, there are a few things I noticed which can still be tested during an interview, even if you're not in the IT field yourself:




          • Behaviour-based questions


          The objective is not to nail the person you have in front of you, but actually see what kind of person they might be. This gives a short window of whether or not they might be suited for working in the company.




          • Past experience questions



          [Could you] Tell me about a situation when...




          For this one, the objective is to invite the person into telling you more about their experience in a specific situation. This type of question can assert their skills as well as their self-being.



          It can be useful if you know the IT teams has some situations which can be difficult to handle (having to handle a lot of tasks in short notice, having to handle tired clients, etc).




          • Problem-solving based question


          You mentioned you are looking for problem-solver.



          I once had an interview with a company where the interviewers didn't ask any programming based question. In order to assert my problem-solving skills, they instead told me about a situation, and I was told to think aloud so they can witness my problem-solving skills in action. For example:




          We have a plane with 50 seats, and 50 passengers awaiting to come in. The first two passengers lost their cards, so they will sit in a random seat. The next passenger will sit in their seat if they can (if it's not already occupied); otherwise, they will sit in a random seat. What is the probability for the last passenger to sit in his own seat?




          The objective is not for them to find the solution, but to show you how they tackle the problem.



          ~~~~~~~~~~



          For each of these questions, remember to take note of the applicant's answer. This way, you can better discuss about them with the IT department manager.






          share|improve this answer





























            1














            Welcome new user, I've come to believe that the only way to find software engineers is, once you've found someone who seems to know what they're talking about,




            • Simply pay them for a one or two week freelance contract. Actually have them jump in and do a real project on your real product with the real team.


            This is becoming more and more common.



            I think that's it.



            It's the only way to know.



            Everything else is useless, as the OP points out.



            The amount of time/money you'll spend on the sundry alternatives ... might as well just put them on the project for a week.



            (Depending on your style and project, you might retain 'em for a time period (a week) or some "task" for $x. Either way.)



            If you consistently take this approach, you'll find after a year or two that, the money you wasted doing this approach, was indeed far less than the sundry other costs of search and hiring.





            Some further thoughts, the tenor of this QA is



            • For software engineers, recruitment processes fail - indeed they're often "hopeless". (One apex of this, and the particular one raised in frustration by the OP, is that hopeful programmers now just "game" the "technical questions" phase of things.)



            • Note that even "google-style" absurdly detailed/extended recruitment processes ............ often completely fail. Programmers (in particular) often "just don't work out" no matter how careful the recruitment processes.



            • By all means in any industry or mode of occupation, folks sometimes "don't work out" even after careful recruitment. However, this is especially a problem for software engineers - it is notorious.



            {You may ask - why? How come it's particularly a problem with programmers? I know precisely why this is, and some people have their own theories on it, but no need to start another argument!}





            Even more thoughts!



            This answer has a big pile of downvotes and a big pile of upvotes.



            Apparently




            • for many folks this is a totally obvious idea


            • but for other folks it is freaky crazy stuff.



            After all, setting aside just programming per se, back in the 90s one of the keys to the staggering success of General Electric at the time was Jack Welch's scheme where each manager simply fired the bottom 10% of people each year! (His book is terrific BTW.)



            And I cringe to type the phrase "the gig economy" but in "the gig economy" we are all on "a trial basis" - from day to day and forever.



            Winnowing programmers is incredibly, notoriously, difficult.






            share|improve this answer



















            • 13




              Hopefully you mean as an off-hours contract project. Or as a final check after a meaningful selection process. Otherwise routinely making your selection only after bringing people onboard as employees is terrible for all concerned - it's expensive of both money and on-boarding effort, and it means often asking people to leave an existing job for a very uncertain alternative.
              – Chris Stratton
              19 hours ago






            • 15




              This may require that the candidate quit his or her current job to try out yours. This may not be bad if you want to hire from the unemployed only, but you're leaving some very promising people wondering "Why should I (quit my job/spend a full week of time off) just to interview?".
              – David Thornley
              17 hours ago






            • 8




              Do you tell your candidates what the process is up front? I would never accept a job offer that said "We don't want to rigorously interview you, we'll just let you work for us for a couple of weeks, and if you're not exactly what we're looking for, you're out the door". That is a huge risk to ask an employee to take, particularly if they have to quit their existing job first.
              – asgallant
              16 hours ago






            • 6




              In a lot of places this idea would be a breach of contract / employment law.
              – Neuromancer
              15 hours ago






            • 4




              What an awful idea.
              – Lightness Races in Orbit
              13 hours ago



















            0














            I don't think you need to change the questions, just how and what you ask.




            It's gotten to the point where you pretty much can't ask a question without the applicant already having pre-studied at least a version of that same task and hence knows, roughly, what the solution is.




            This isn't a zero sum thing, you can feed off the solution for an entire interview on it's own if you want, and get a deep understanding of the interviewee's skills (assuming as the interviewer you have your own technical skills).



            You present the question, the interviewee creates a solution (maybe code, maybe whiteboard). This is the start:




            • Tell me how this works

            • What factors led you to choose this solution?

            • Are there any other ways of doing this?

            • Why is your solution better than the others?

            • Are there any potential advantages in the other solutions missing from your solution? what scenarios might that apply?

            • Having just written this off the cuff, any refactorings you'd like to do now you've looked it over?

            • If you didn't do this test driven, what tests would you be looking to write/do to ensure this is correct?

            • Any bugs you've noticed?

            • Do you think the code is production quality? Could another developer support/refactor it without knowledge transfer from you? What would you need to change to ensure it's intent is understood?


            Someone who has memorized an algorithm or pattern without understanding it will not be able to drill down into detail, but a good developer should be able to have discussions on these topics, even if their raw solution wasn't perfect (and seeing someone discover a better solution while talking to you and be prepared to call it out shows a maturity over code/design reviews and refactoring which are highly desirable).






            share|improve this answer






















              protected by Jane S 9 hours ago



              Thank you for your interest in this question.
              Because it has attracted low-quality or spam answers that had to be removed, posting an answer now requires 10 reputation on this site (the association bonus does not count).



              Would you like to answer one of these unanswered questions instead?














              15 Answers
              15






              active

              oldest

              votes








              15 Answers
              15






              active

              oldest

              votes









              active

              oldest

              votes






              active

              oldest

              votes









              69














              Provide the candidate with a genuine programming test in the interview - a laptop hooked up to a projector with a broken project, with a mixture of basic to complex bugs, and ask them to add some functionality, again ranging from basic to moderately complex. This is something nobody can really study for and will actually provide a showcase of their skills. Have technical people there talking to the candidate to get a feel for their personality and how they approach the problems faced.



              For the job interview for my current role, I had spent 2 weeks studying programming principles, design patterns, database stuff etc. I was able to answer all the theoretical questions well and think I came across well



              I was then handed a laptop which was connected up to the projector and shown a solution which contained a broken website with a defined number of errors which I had to debug and add some simple functionality. While I wasn't very familiar with the front-end framework used by the company, I was able to fix about half the bugs and then give my best guess as to what the causes were for the remaining bugs based on what I could see, and this was good enough to get me in the door.



              The whole thing, between the theoretical questions and the website debugging session lasted about 2 hours.






              share|improve this answer



















              • 30




                Note that this approach, while highly informative, requires a technically competent observer to rate the interviewee's work.
                – chrylis
                16 hours ago






              • 8




                @chrylis only a unicorn HR person would have the technical know-how to hire somebody without the need to having a technical person on hand. The issue is that the OP is saying that the technical tests questions they are asking have already been prepared for.
                – user1666620
                15 hours ago








              • 13




                @chrylis in that case they're morons and deserve every incompetent they get
                – user1666620
                15 hours ago






              • 15




                @chrylis Any approach will require a technically competent observer. There is simply no way in general for a non-technical person to judge programming ability, as far as I've been able to tell.
                – David Thornley
                15 hours ago






              • 25




                Be very obvious in the source code that this is all contrived source. You don’t want someone thinking you’re trying to get two hours of free labour out of them.
                – Ian MacDonald
                13 hours ago
















              69














              Provide the candidate with a genuine programming test in the interview - a laptop hooked up to a projector with a broken project, with a mixture of basic to complex bugs, and ask them to add some functionality, again ranging from basic to moderately complex. This is something nobody can really study for and will actually provide a showcase of their skills. Have technical people there talking to the candidate to get a feel for their personality and how they approach the problems faced.



              For the job interview for my current role, I had spent 2 weeks studying programming principles, design patterns, database stuff etc. I was able to answer all the theoretical questions well and think I came across well



              I was then handed a laptop which was connected up to the projector and shown a solution which contained a broken website with a defined number of errors which I had to debug and add some simple functionality. While I wasn't very familiar with the front-end framework used by the company, I was able to fix about half the bugs and then give my best guess as to what the causes were for the remaining bugs based on what I could see, and this was good enough to get me in the door.



              The whole thing, between the theoretical questions and the website debugging session lasted about 2 hours.






              share|improve this answer



















              • 30




                Note that this approach, while highly informative, requires a technically competent observer to rate the interviewee's work.
                – chrylis
                16 hours ago






              • 8




                @chrylis only a unicorn HR person would have the technical know-how to hire somebody without the need to having a technical person on hand. The issue is that the OP is saying that the technical tests questions they are asking have already been prepared for.
                – user1666620
                15 hours ago








              • 13




                @chrylis in that case they're morons and deserve every incompetent they get
                – user1666620
                15 hours ago






              • 15




                @chrylis Any approach will require a technically competent observer. There is simply no way in general for a non-technical person to judge programming ability, as far as I've been able to tell.
                – David Thornley
                15 hours ago






              • 25




                Be very obvious in the source code that this is all contrived source. You don’t want someone thinking you’re trying to get two hours of free labour out of them.
                – Ian MacDonald
                13 hours ago














              69












              69








              69






              Provide the candidate with a genuine programming test in the interview - a laptop hooked up to a projector with a broken project, with a mixture of basic to complex bugs, and ask them to add some functionality, again ranging from basic to moderately complex. This is something nobody can really study for and will actually provide a showcase of their skills. Have technical people there talking to the candidate to get a feel for their personality and how they approach the problems faced.



              For the job interview for my current role, I had spent 2 weeks studying programming principles, design patterns, database stuff etc. I was able to answer all the theoretical questions well and think I came across well



              I was then handed a laptop which was connected up to the projector and shown a solution which contained a broken website with a defined number of errors which I had to debug and add some simple functionality. While I wasn't very familiar with the front-end framework used by the company, I was able to fix about half the bugs and then give my best guess as to what the causes were for the remaining bugs based on what I could see, and this was good enough to get me in the door.



              The whole thing, between the theoretical questions and the website debugging session lasted about 2 hours.






              share|improve this answer














              Provide the candidate with a genuine programming test in the interview - a laptop hooked up to a projector with a broken project, with a mixture of basic to complex bugs, and ask them to add some functionality, again ranging from basic to moderately complex. This is something nobody can really study for and will actually provide a showcase of their skills. Have technical people there talking to the candidate to get a feel for their personality and how they approach the problems faced.



              For the job interview for my current role, I had spent 2 weeks studying programming principles, design patterns, database stuff etc. I was able to answer all the theoretical questions well and think I came across well



              I was then handed a laptop which was connected up to the projector and shown a solution which contained a broken website with a defined number of errors which I had to debug and add some simple functionality. While I wasn't very familiar with the front-end framework used by the company, I was able to fix about half the bugs and then give my best guess as to what the causes were for the remaining bugs based on what I could see, and this was good enough to get me in the door.



              The whole thing, between the theoretical questions and the website debugging session lasted about 2 hours.







              share|improve this answer














              share|improve this answer



              share|improve this answer








              edited 19 hours ago

























              answered 19 hours ago









              user1666620

              9,63673334




              9,63673334








              • 30




                Note that this approach, while highly informative, requires a technically competent observer to rate the interviewee's work.
                – chrylis
                16 hours ago






              • 8




                @chrylis only a unicorn HR person would have the technical know-how to hire somebody without the need to having a technical person on hand. The issue is that the OP is saying that the technical tests questions they are asking have already been prepared for.
                – user1666620
                15 hours ago








              • 13




                @chrylis in that case they're morons and deserve every incompetent they get
                – user1666620
                15 hours ago






              • 15




                @chrylis Any approach will require a technically competent observer. There is simply no way in general for a non-technical person to judge programming ability, as far as I've been able to tell.
                – David Thornley
                15 hours ago






              • 25




                Be very obvious in the source code that this is all contrived source. You don’t want someone thinking you’re trying to get two hours of free labour out of them.
                – Ian MacDonald
                13 hours ago














              • 30




                Note that this approach, while highly informative, requires a technically competent observer to rate the interviewee's work.
                – chrylis
                16 hours ago






              • 8




                @chrylis only a unicorn HR person would have the technical know-how to hire somebody without the need to having a technical person on hand. The issue is that the OP is saying that the technical tests questions they are asking have already been prepared for.
                – user1666620
                15 hours ago








              • 13




                @chrylis in that case they're morons and deserve every incompetent they get
                – user1666620
                15 hours ago






              • 15




                @chrylis Any approach will require a technically competent observer. There is simply no way in general for a non-technical person to judge programming ability, as far as I've been able to tell.
                – David Thornley
                15 hours ago






              • 25




                Be very obvious in the source code that this is all contrived source. You don’t want someone thinking you’re trying to get two hours of free labour out of them.
                – Ian MacDonald
                13 hours ago








              30




              30




              Note that this approach, while highly informative, requires a technically competent observer to rate the interviewee's work.
              – chrylis
              16 hours ago




              Note that this approach, while highly informative, requires a technically competent observer to rate the interviewee's work.
              – chrylis
              16 hours ago




              8




              8




              @chrylis only a unicorn HR person would have the technical know-how to hire somebody without the need to having a technical person on hand. The issue is that the OP is saying that the technical tests questions they are asking have already been prepared for.
              – user1666620
              15 hours ago






              @chrylis only a unicorn HR person would have the technical know-how to hire somebody without the need to having a technical person on hand. The issue is that the OP is saying that the technical tests questions they are asking have already been prepared for.
              – user1666620
              15 hours ago






              13




              13




              @chrylis in that case they're morons and deserve every incompetent they get
              – user1666620
              15 hours ago




              @chrylis in that case they're morons and deserve every incompetent they get
              – user1666620
              15 hours ago




              15




              15




              @chrylis Any approach will require a technically competent observer. There is simply no way in general for a non-technical person to judge programming ability, as far as I've been able to tell.
              – David Thornley
              15 hours ago




              @chrylis Any approach will require a technically competent observer. There is simply no way in general for a non-technical person to judge programming ability, as far as I've been able to tell.
              – David Thornley
              15 hours ago




              25




              25




              Be very obvious in the source code that this is all contrived source. You don’t want someone thinking you’re trying to get two hours of free labour out of them.
              – Ian MacDonald
              13 hours ago




              Be very obvious in the source code that this is all contrived source. You don’t want someone thinking you’re trying to get two hours of free labour out of them.
              – Ian MacDonald
              13 hours ago













              39















              once you actually get the job, you'll most likely never run into any of those problems from the job interview book again




              If their job doesn't involve solving those kinds of problems, why test them on them in the first place?



              Why not give them a real problem they would encounter on the job instead?



              That's my recommendation. Surely you will have many examples of real on-the-job problems to choose from to find a suitable one.






              share|improve this answer








              New contributor




              Alexander O'Mara is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
              Check out our Code of Conduct.


















              • This answer does not appear to differ significantly from user1666620's.
                – jpmc26
                9 hours ago






              • 2




                They are somewhat similar in suggested solution. I thought it was important to address why their current method isn't testing what they actually wanted though, and suggest that new tests could be as simple as using recent challenges programmers have faced, rather than inventing new contrived tests.
                – Alexander O'Mara
                9 hours ago










              • @jpmc26 I would say that this answer more clearly identifies the root of the problem. The OP is clearly asking the wrong questions. Sure, the final suggestion is more or less the same for both of these answers, but stopping to ask the OP "why are you asking your current questions?" is a very important addition.
                – Conor Mancone
                20 mins ago
















              39















              once you actually get the job, you'll most likely never run into any of those problems from the job interview book again




              If their job doesn't involve solving those kinds of problems, why test them on them in the first place?



              Why not give them a real problem they would encounter on the job instead?



              That's my recommendation. Surely you will have many examples of real on-the-job problems to choose from to find a suitable one.






              share|improve this answer








              New contributor




              Alexander O'Mara is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
              Check out our Code of Conduct.


















              • This answer does not appear to differ significantly from user1666620's.
                – jpmc26
                9 hours ago






              • 2




                They are somewhat similar in suggested solution. I thought it was important to address why their current method isn't testing what they actually wanted though, and suggest that new tests could be as simple as using recent challenges programmers have faced, rather than inventing new contrived tests.
                – Alexander O'Mara
                9 hours ago










              • @jpmc26 I would say that this answer more clearly identifies the root of the problem. The OP is clearly asking the wrong questions. Sure, the final suggestion is more or less the same for both of these answers, but stopping to ask the OP "why are you asking your current questions?" is a very important addition.
                – Conor Mancone
                20 mins ago














              39












              39








              39







              once you actually get the job, you'll most likely never run into any of those problems from the job interview book again




              If their job doesn't involve solving those kinds of problems, why test them on them in the first place?



              Why not give them a real problem they would encounter on the job instead?



              That's my recommendation. Surely you will have many examples of real on-the-job problems to choose from to find a suitable one.






              share|improve this answer








              New contributor




              Alexander O'Mara is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
              Check out our Code of Conduct.










              once you actually get the job, you'll most likely never run into any of those problems from the job interview book again




              If their job doesn't involve solving those kinds of problems, why test them on them in the first place?



              Why not give them a real problem they would encounter on the job instead?



              That's my recommendation. Surely you will have many examples of real on-the-job problems to choose from to find a suitable one.







              share|improve this answer








              New contributor




              Alexander O'Mara is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
              Check out our Code of Conduct.









              share|improve this answer



              share|improve this answer






              New contributor




              Alexander O'Mara is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
              Check out our Code of Conduct.









              answered 15 hours ago









              Alexander O'Mara

              31114




              31114




              New contributor




              Alexander O'Mara is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
              Check out our Code of Conduct.





              New contributor





              Alexander O'Mara is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
              Check out our Code of Conduct.






              Alexander O'Mara is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
              Check out our Code of Conduct.












              • This answer does not appear to differ significantly from user1666620's.
                – jpmc26
                9 hours ago






              • 2




                They are somewhat similar in suggested solution. I thought it was important to address why their current method isn't testing what they actually wanted though, and suggest that new tests could be as simple as using recent challenges programmers have faced, rather than inventing new contrived tests.
                – Alexander O'Mara
                9 hours ago










              • @jpmc26 I would say that this answer more clearly identifies the root of the problem. The OP is clearly asking the wrong questions. Sure, the final suggestion is more or less the same for both of these answers, but stopping to ask the OP "why are you asking your current questions?" is a very important addition.
                – Conor Mancone
                20 mins ago


















              • This answer does not appear to differ significantly from user1666620's.
                – jpmc26
                9 hours ago






              • 2




                They are somewhat similar in suggested solution. I thought it was important to address why their current method isn't testing what they actually wanted though, and suggest that new tests could be as simple as using recent challenges programmers have faced, rather than inventing new contrived tests.
                – Alexander O'Mara
                9 hours ago










              • @jpmc26 I would say that this answer more clearly identifies the root of the problem. The OP is clearly asking the wrong questions. Sure, the final suggestion is more or less the same for both of these answers, but stopping to ask the OP "why are you asking your current questions?" is a very important addition.
                – Conor Mancone
                20 mins ago
















              This answer does not appear to differ significantly from user1666620's.
              – jpmc26
              9 hours ago




              This answer does not appear to differ significantly from user1666620's.
              – jpmc26
              9 hours ago




              2




              2




              They are somewhat similar in suggested solution. I thought it was important to address why their current method isn't testing what they actually wanted though, and suggest that new tests could be as simple as using recent challenges programmers have faced, rather than inventing new contrived tests.
              – Alexander O'Mara
              9 hours ago




              They are somewhat similar in suggested solution. I thought it was important to address why their current method isn't testing what they actually wanted though, and suggest that new tests could be as simple as using recent challenges programmers have faced, rather than inventing new contrived tests.
              – Alexander O'Mara
              9 hours ago












              @jpmc26 I would say that this answer more clearly identifies the root of the problem. The OP is clearly asking the wrong questions. Sure, the final suggestion is more or less the same for both of these answers, but stopping to ask the OP "why are you asking your current questions?" is a very important addition.
              – Conor Mancone
              20 mins ago




              @jpmc26 I would say that this answer more clearly identifies the root of the problem. The OP is clearly asking the wrong questions. Sure, the final suggestion is more or less the same for both of these answers, but stopping to ask the OP "why are you asking your current questions?" is a very important addition.
              – Conor Mancone
              20 mins ago











              13















              • Have multiple interviewers. Your strongest engineers on the team should participate in the interview process - they definitely want to work with people better than the one's that are struggling, right? Let other engineers conduct their own 1 on 1 interview. And have another engineer do the initial phone screens.


              • Ask an open ended design question. for a problem of medium complexity. Ask the candidate to write out the header file, class declarations, box diagrams, etc... Does the candidate ask clarifying questions? After he's done with a basic design, introduce a new requirement that would break his design. Is he able to pivot? Pick one part of his design and probe deeper.



              • Ask a question that probes if they have a deep understanding of the platform fundamentals. Some examples I've asked.




                • "How does the C++ compiler implement virtual methods?"

                • "How do closures work in Javascript?"

                • "Explain when you would ever want to use UDP instead of TCP."

                • "After you type a www.foo.com into a browser address bar, tell me about all the network activity and protocols involved to get the content on the screen."



              • Probe for genuine interest in programming. "Tell me about a program you wrote for fun that wasn't for work or school." A good candidate will tell you about an app, website, or hack that he did for his own personal pleasure. A weaker candidate will only tell you about the program he wrote to figure something out for work/school.







              share|improve this answer



















              • 23




                Probe for genuine interest in programming - theoretically good paragraph but... I have small kids and this is my priority when I'm not in the office + I spend 4 hours per day commuting to my current office location. I have no time for hobby other than watching maybe one movie per week, not to mention running an own project. It says nothing about my commitment at work nor about my skills.
                – ElmoVanKielmo
                15 hours ago










              • @ElmoVanKielmo interviewing criteria will reflect the interviewer's biases/preferences. For example, for any valuable skill/criterion X, you can argue "I know successful people that don't have X". But if the company is full of the type that know X, probably not going to be a good fit either way.
                – Chan-Ho Suh
                14 hours ago






              • 4




                "How does the C++ compiler implement virtual methods?" Which one? And what do you mean by "methods" since this isn't a standard term in C++? ;) (inb4 "thank you for coming, we'll let you know"; whoops)
                – Lightness Races in Orbit
                13 hours ago








              • 3




                Those are good sample questions and remind me of the questions I asked when interviewing in the past. We got good results thanks to this selection process. You'd be amazed (or not) at how many apparently qualified candidates can't talk you through the very basics of an HTTP request or the difference between TCP and UDP. And, yes, they'd claimed knowledge in those spheres.
                – Lightness Races in Orbit
                13 hours ago












              • Having all your other engineers come in rarely achieves anything concrete. Everyone ends up just talking and batting stuff around. If you do want to try that approach, its better that the other engineers think out and write down a difficult question.
                – Fattie
                7 hours ago


















              13















              • Have multiple interviewers. Your strongest engineers on the team should participate in the interview process - they definitely want to work with people better than the one's that are struggling, right? Let other engineers conduct their own 1 on 1 interview. And have another engineer do the initial phone screens.


              • Ask an open ended design question. for a problem of medium complexity. Ask the candidate to write out the header file, class declarations, box diagrams, etc... Does the candidate ask clarifying questions? After he's done with a basic design, introduce a new requirement that would break his design. Is he able to pivot? Pick one part of his design and probe deeper.



              • Ask a question that probes if they have a deep understanding of the platform fundamentals. Some examples I've asked.




                • "How does the C++ compiler implement virtual methods?"

                • "How do closures work in Javascript?"

                • "Explain when you would ever want to use UDP instead of TCP."

                • "After you type a www.foo.com into a browser address bar, tell me about all the network activity and protocols involved to get the content on the screen."



              • Probe for genuine interest in programming. "Tell me about a program you wrote for fun that wasn't for work or school." A good candidate will tell you about an app, website, or hack that he did for his own personal pleasure. A weaker candidate will only tell you about the program he wrote to figure something out for work/school.







              share|improve this answer



















              • 23




                Probe for genuine interest in programming - theoretically good paragraph but... I have small kids and this is my priority when I'm not in the office + I spend 4 hours per day commuting to my current office location. I have no time for hobby other than watching maybe one movie per week, not to mention running an own project. It says nothing about my commitment at work nor about my skills.
                – ElmoVanKielmo
                15 hours ago










              • @ElmoVanKielmo interviewing criteria will reflect the interviewer's biases/preferences. For example, for any valuable skill/criterion X, you can argue "I know successful people that don't have X". But if the company is full of the type that know X, probably not going to be a good fit either way.
                – Chan-Ho Suh
                14 hours ago






              • 4




                "How does the C++ compiler implement virtual methods?" Which one? And what do you mean by "methods" since this isn't a standard term in C++? ;) (inb4 "thank you for coming, we'll let you know"; whoops)
                – Lightness Races in Orbit
                13 hours ago








              • 3




                Those are good sample questions and remind me of the questions I asked when interviewing in the past. We got good results thanks to this selection process. You'd be amazed (or not) at how many apparently qualified candidates can't talk you through the very basics of an HTTP request or the difference between TCP and UDP. And, yes, they'd claimed knowledge in those spheres.
                – Lightness Races in Orbit
                13 hours ago












              • Having all your other engineers come in rarely achieves anything concrete. Everyone ends up just talking and batting stuff around. If you do want to try that approach, its better that the other engineers think out and write down a difficult question.
                – Fattie
                7 hours ago
















              13












              13








              13







              • Have multiple interviewers. Your strongest engineers on the team should participate in the interview process - they definitely want to work with people better than the one's that are struggling, right? Let other engineers conduct their own 1 on 1 interview. And have another engineer do the initial phone screens.


              • Ask an open ended design question. for a problem of medium complexity. Ask the candidate to write out the header file, class declarations, box diagrams, etc... Does the candidate ask clarifying questions? After he's done with a basic design, introduce a new requirement that would break his design. Is he able to pivot? Pick one part of his design and probe deeper.



              • Ask a question that probes if they have a deep understanding of the platform fundamentals. Some examples I've asked.




                • "How does the C++ compiler implement virtual methods?"

                • "How do closures work in Javascript?"

                • "Explain when you would ever want to use UDP instead of TCP."

                • "After you type a www.foo.com into a browser address bar, tell me about all the network activity and protocols involved to get the content on the screen."



              • Probe for genuine interest in programming. "Tell me about a program you wrote for fun that wasn't for work or school." A good candidate will tell you about an app, website, or hack that he did for his own personal pleasure. A weaker candidate will only tell you about the program he wrote to figure something out for work/school.







              share|improve this answer















              • Have multiple interviewers. Your strongest engineers on the team should participate in the interview process - they definitely want to work with people better than the one's that are struggling, right? Let other engineers conduct their own 1 on 1 interview. And have another engineer do the initial phone screens.


              • Ask an open ended design question. for a problem of medium complexity. Ask the candidate to write out the header file, class declarations, box diagrams, etc... Does the candidate ask clarifying questions? After he's done with a basic design, introduce a new requirement that would break his design. Is he able to pivot? Pick one part of his design and probe deeper.



              • Ask a question that probes if they have a deep understanding of the platform fundamentals. Some examples I've asked.




                • "How does the C++ compiler implement virtual methods?"

                • "How do closures work in Javascript?"

                • "Explain when you would ever want to use UDP instead of TCP."

                • "After you type a www.foo.com into a browser address bar, tell me about all the network activity and protocols involved to get the content on the screen."



              • Probe for genuine interest in programming. "Tell me about a program you wrote for fun that wasn't for work or school." A good candidate will tell you about an app, website, or hack that he did for his own personal pleasure. A weaker candidate will only tell you about the program he wrote to figure something out for work/school.








              share|improve this answer














              share|improve this answer



              share|improve this answer








              edited 6 hours ago

























              answered 18 hours ago









              selbie

              87929




              87929








              • 23




                Probe for genuine interest in programming - theoretically good paragraph but... I have small kids and this is my priority when I'm not in the office + I spend 4 hours per day commuting to my current office location. I have no time for hobby other than watching maybe one movie per week, not to mention running an own project. It says nothing about my commitment at work nor about my skills.
                – ElmoVanKielmo
                15 hours ago










              • @ElmoVanKielmo interviewing criteria will reflect the interviewer's biases/preferences. For example, for any valuable skill/criterion X, you can argue "I know successful people that don't have X". But if the company is full of the type that know X, probably not going to be a good fit either way.
                – Chan-Ho Suh
                14 hours ago






              • 4




                "How does the C++ compiler implement virtual methods?" Which one? And what do you mean by "methods" since this isn't a standard term in C++? ;) (inb4 "thank you for coming, we'll let you know"; whoops)
                – Lightness Races in Orbit
                13 hours ago








              • 3




                Those are good sample questions and remind me of the questions I asked when interviewing in the past. We got good results thanks to this selection process. You'd be amazed (or not) at how many apparently qualified candidates can't talk you through the very basics of an HTTP request or the difference between TCP and UDP. And, yes, they'd claimed knowledge in those spheres.
                – Lightness Races in Orbit
                13 hours ago












              • Having all your other engineers come in rarely achieves anything concrete. Everyone ends up just talking and batting stuff around. If you do want to try that approach, its better that the other engineers think out and write down a difficult question.
                – Fattie
                7 hours ago
















              • 23




                Probe for genuine interest in programming - theoretically good paragraph but... I have small kids and this is my priority when I'm not in the office + I spend 4 hours per day commuting to my current office location. I have no time for hobby other than watching maybe one movie per week, not to mention running an own project. It says nothing about my commitment at work nor about my skills.
                – ElmoVanKielmo
                15 hours ago










              • @ElmoVanKielmo interviewing criteria will reflect the interviewer's biases/preferences. For example, for any valuable skill/criterion X, you can argue "I know successful people that don't have X". But if the company is full of the type that know X, probably not going to be a good fit either way.
                – Chan-Ho Suh
                14 hours ago






              • 4




                "How does the C++ compiler implement virtual methods?" Which one? And what do you mean by "methods" since this isn't a standard term in C++? ;) (inb4 "thank you for coming, we'll let you know"; whoops)
                – Lightness Races in Orbit
                13 hours ago








              • 3




                Those are good sample questions and remind me of the questions I asked when interviewing in the past. We got good results thanks to this selection process. You'd be amazed (or not) at how many apparently qualified candidates can't talk you through the very basics of an HTTP request or the difference between TCP and UDP. And, yes, they'd claimed knowledge in those spheres.
                – Lightness Races in Orbit
                13 hours ago












              • Having all your other engineers come in rarely achieves anything concrete. Everyone ends up just talking and batting stuff around. If you do want to try that approach, its better that the other engineers think out and write down a difficult question.
                – Fattie
                7 hours ago










              23




              23




              Probe for genuine interest in programming - theoretically good paragraph but... I have small kids and this is my priority when I'm not in the office + I spend 4 hours per day commuting to my current office location. I have no time for hobby other than watching maybe one movie per week, not to mention running an own project. It says nothing about my commitment at work nor about my skills.
              – ElmoVanKielmo
              15 hours ago




              Probe for genuine interest in programming - theoretically good paragraph but... I have small kids and this is my priority when I'm not in the office + I spend 4 hours per day commuting to my current office location. I have no time for hobby other than watching maybe one movie per week, not to mention running an own project. It says nothing about my commitment at work nor about my skills.
              – ElmoVanKielmo
              15 hours ago












              @ElmoVanKielmo interviewing criteria will reflect the interviewer's biases/preferences. For example, for any valuable skill/criterion X, you can argue "I know successful people that don't have X". But if the company is full of the type that know X, probably not going to be a good fit either way.
              – Chan-Ho Suh
              14 hours ago




              @ElmoVanKielmo interviewing criteria will reflect the interviewer's biases/preferences. For example, for any valuable skill/criterion X, you can argue "I know successful people that don't have X". But if the company is full of the type that know X, probably not going to be a good fit either way.
              – Chan-Ho Suh
              14 hours ago




              4




              4




              "How does the C++ compiler implement virtual methods?" Which one? And what do you mean by "methods" since this isn't a standard term in C++? ;) (inb4 "thank you for coming, we'll let you know"; whoops)
              – Lightness Races in Orbit
              13 hours ago






              "How does the C++ compiler implement virtual methods?" Which one? And what do you mean by "methods" since this isn't a standard term in C++? ;) (inb4 "thank you for coming, we'll let you know"; whoops)
              – Lightness Races in Orbit
              13 hours ago






              3




              3




              Those are good sample questions and remind me of the questions I asked when interviewing in the past. We got good results thanks to this selection process. You'd be amazed (or not) at how many apparently qualified candidates can't talk you through the very basics of an HTTP request or the difference between TCP and UDP. And, yes, they'd claimed knowledge in those spheres.
              – Lightness Races in Orbit
              13 hours ago






              Those are good sample questions and remind me of the questions I asked when interviewing in the past. We got good results thanks to this selection process. You'd be amazed (or not) at how many apparently qualified candidates can't talk you through the very basics of an HTTP request or the difference between TCP and UDP. And, yes, they'd claimed knowledge in those spheres.
              – Lightness Races in Orbit
              13 hours ago














              Having all your other engineers come in rarely achieves anything concrete. Everyone ends up just talking and batting stuff around. If you do want to try that approach, its better that the other engineers think out and write down a difficult question.
              – Fattie
              7 hours ago






              Having all your other engineers come in rarely achieves anything concrete. Everyone ends up just talking and batting stuff around. If you do want to try that approach, its better that the other engineers think out and write down a difficult question.
              – Fattie
              7 hours ago













              7














              I've been most of my life as an electrical engineer, and back in the 90s many of the companies I'd interview with stopped asking me questions about electrical engineering. Between my schooling and my work resume, it was obvious to them that I knew enough about electrical engineering to meet their needs. What did they ask about?



              My personality. My ability to work in (and lead) a team. My cross-discipline skills. My capacity to learn.



              To be ruthlessly blunt, engineering skills (especially programming skills) are a dime a dozen. There are so many basically competent people out there that there is nothing about programming or engineering that's worth asking (unless you're interviewing a new graduate with no internship experience).



              What's important is being sure the candidate is suitable for your environment. How well will they work with the existing personalities in your company? Do they bring more to the table than the skills needed for the basic job? How quickly can they come up to speed with changes in company direction? technology? or design standards? Are they willing to work beyond the basic job, providing (e.g.) scholarly articles, conference presentaions, patents, and other "bring honor to the company" activities? And can they show that they can do any of this?



              I can sum this up with a comment I made to Philips Semiconductor recruiters long ago (as an employee). I can teach a 10-year-old to connect the dots when it comes to microelectronic design. Teaching them WHY you connect those dots is another matter. Therefore, you can't judge a new employee by how well they connect the dots. You have to find ways to discover how well they know WHY they're doing what they're doing. That's where teamwork and extra-curricular activities come in. They show depth of understanding.






              share|improve this answer








              New contributor




              JBH is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
              Check out our Code of Conduct.














              • 11




                "There are so many basically competent people out there that there is nothing about programming or engineering that's worth asking (unless you're interviewing a new graduate with no internship experience)." I don't agree. I've had a bunch of people in for interview who looked great on paper but couldn't answer even some pretty basic questions about fundamental commonplace technologies. We didn't even get as far as fit, though that is of course also important. I'm happy to hear that you were qualified for the roles you applied for, but this is definitely not the case for all candidates.
                – Lightness Races in Orbit
                13 hours ago






              • 1




                Right, this is not the case with software. Almost all "programmers" are barely competent, have a self-taught hobbyist vibe, and can't actually do anything. The OP is perfectly correct that folks drill to answer "interview type questions" you can look up online. The QA is about how to solve this problem.
                – Fattie
                7 hours ago










              • And if you need highly competent people there are not as many as there are needed.
                – Thorbjørn Ravn Andersen
                35 mins ago
















              7














              I've been most of my life as an electrical engineer, and back in the 90s many of the companies I'd interview with stopped asking me questions about electrical engineering. Between my schooling and my work resume, it was obvious to them that I knew enough about electrical engineering to meet their needs. What did they ask about?



              My personality. My ability to work in (and lead) a team. My cross-discipline skills. My capacity to learn.



              To be ruthlessly blunt, engineering skills (especially programming skills) are a dime a dozen. There are so many basically competent people out there that there is nothing about programming or engineering that's worth asking (unless you're interviewing a new graduate with no internship experience).



              What's important is being sure the candidate is suitable for your environment. How well will they work with the existing personalities in your company? Do they bring more to the table than the skills needed for the basic job? How quickly can they come up to speed with changes in company direction? technology? or design standards? Are they willing to work beyond the basic job, providing (e.g.) scholarly articles, conference presentaions, patents, and other "bring honor to the company" activities? And can they show that they can do any of this?



              I can sum this up with a comment I made to Philips Semiconductor recruiters long ago (as an employee). I can teach a 10-year-old to connect the dots when it comes to microelectronic design. Teaching them WHY you connect those dots is another matter. Therefore, you can't judge a new employee by how well they connect the dots. You have to find ways to discover how well they know WHY they're doing what they're doing. That's where teamwork and extra-curricular activities come in. They show depth of understanding.






              share|improve this answer








              New contributor




              JBH is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
              Check out our Code of Conduct.














              • 11




                "There are so many basically competent people out there that there is nothing about programming or engineering that's worth asking (unless you're interviewing a new graduate with no internship experience)." I don't agree. I've had a bunch of people in for interview who looked great on paper but couldn't answer even some pretty basic questions about fundamental commonplace technologies. We didn't even get as far as fit, though that is of course also important. I'm happy to hear that you were qualified for the roles you applied for, but this is definitely not the case for all candidates.
                – Lightness Races in Orbit
                13 hours ago






              • 1




                Right, this is not the case with software. Almost all "programmers" are barely competent, have a self-taught hobbyist vibe, and can't actually do anything. The OP is perfectly correct that folks drill to answer "interview type questions" you can look up online. The QA is about how to solve this problem.
                – Fattie
                7 hours ago










              • And if you need highly competent people there are not as many as there are needed.
                – Thorbjørn Ravn Andersen
                35 mins ago














              7












              7








              7






              I've been most of my life as an electrical engineer, and back in the 90s many of the companies I'd interview with stopped asking me questions about electrical engineering. Between my schooling and my work resume, it was obvious to them that I knew enough about electrical engineering to meet their needs. What did they ask about?



              My personality. My ability to work in (and lead) a team. My cross-discipline skills. My capacity to learn.



              To be ruthlessly blunt, engineering skills (especially programming skills) are a dime a dozen. There are so many basically competent people out there that there is nothing about programming or engineering that's worth asking (unless you're interviewing a new graduate with no internship experience).



              What's important is being sure the candidate is suitable for your environment. How well will they work with the existing personalities in your company? Do they bring more to the table than the skills needed for the basic job? How quickly can they come up to speed with changes in company direction? technology? or design standards? Are they willing to work beyond the basic job, providing (e.g.) scholarly articles, conference presentaions, patents, and other "bring honor to the company" activities? And can they show that they can do any of this?



              I can sum this up with a comment I made to Philips Semiconductor recruiters long ago (as an employee). I can teach a 10-year-old to connect the dots when it comes to microelectronic design. Teaching them WHY you connect those dots is another matter. Therefore, you can't judge a new employee by how well they connect the dots. You have to find ways to discover how well they know WHY they're doing what they're doing. That's where teamwork and extra-curricular activities come in. They show depth of understanding.






              share|improve this answer








              New contributor




              JBH is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
              Check out our Code of Conduct.









              I've been most of my life as an electrical engineer, and back in the 90s many of the companies I'd interview with stopped asking me questions about electrical engineering. Between my schooling and my work resume, it was obvious to them that I knew enough about electrical engineering to meet their needs. What did they ask about?



              My personality. My ability to work in (and lead) a team. My cross-discipline skills. My capacity to learn.



              To be ruthlessly blunt, engineering skills (especially programming skills) are a dime a dozen. There are so many basically competent people out there that there is nothing about programming or engineering that's worth asking (unless you're interviewing a new graduate with no internship experience).



              What's important is being sure the candidate is suitable for your environment. How well will they work with the existing personalities in your company? Do they bring more to the table than the skills needed for the basic job? How quickly can they come up to speed with changes in company direction? technology? or design standards? Are they willing to work beyond the basic job, providing (e.g.) scholarly articles, conference presentaions, patents, and other "bring honor to the company" activities? And can they show that they can do any of this?



              I can sum this up with a comment I made to Philips Semiconductor recruiters long ago (as an employee). I can teach a 10-year-old to connect the dots when it comes to microelectronic design. Teaching them WHY you connect those dots is another matter. Therefore, you can't judge a new employee by how well they connect the dots. You have to find ways to discover how well they know WHY they're doing what they're doing. That's where teamwork and extra-curricular activities come in. They show depth of understanding.







              share|improve this answer








              New contributor




              JBH is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
              Check out our Code of Conduct.









              share|improve this answer



              share|improve this answer






              New contributor




              JBH is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
              Check out our Code of Conduct.









              answered 15 hours ago









              JBH

              4255




              4255




              New contributor




              JBH is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
              Check out our Code of Conduct.





              New contributor





              JBH is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
              Check out our Code of Conduct.






              JBH is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
              Check out our Code of Conduct.








              • 11




                "There are so many basically competent people out there that there is nothing about programming or engineering that's worth asking (unless you're interviewing a new graduate with no internship experience)." I don't agree. I've had a bunch of people in for interview who looked great on paper but couldn't answer even some pretty basic questions about fundamental commonplace technologies. We didn't even get as far as fit, though that is of course also important. I'm happy to hear that you were qualified for the roles you applied for, but this is definitely not the case for all candidates.
                – Lightness Races in Orbit
                13 hours ago






              • 1




                Right, this is not the case with software. Almost all "programmers" are barely competent, have a self-taught hobbyist vibe, and can't actually do anything. The OP is perfectly correct that folks drill to answer "interview type questions" you can look up online. The QA is about how to solve this problem.
                – Fattie
                7 hours ago










              • And if you need highly competent people there are not as many as there are needed.
                – Thorbjørn Ravn Andersen
                35 mins ago














              • 11




                "There are so many basically competent people out there that there is nothing about programming or engineering that's worth asking (unless you're interviewing a new graduate with no internship experience)." I don't agree. I've had a bunch of people in for interview who looked great on paper but couldn't answer even some pretty basic questions about fundamental commonplace technologies. We didn't even get as far as fit, though that is of course also important. I'm happy to hear that you were qualified for the roles you applied for, but this is definitely not the case for all candidates.
                – Lightness Races in Orbit
                13 hours ago






              • 1




                Right, this is not the case with software. Almost all "programmers" are barely competent, have a self-taught hobbyist vibe, and can't actually do anything. The OP is perfectly correct that folks drill to answer "interview type questions" you can look up online. The QA is about how to solve this problem.
                – Fattie
                7 hours ago










              • And if you need highly competent people there are not as many as there are needed.
                – Thorbjørn Ravn Andersen
                35 mins ago








              11




              11




              "There are so many basically competent people out there that there is nothing about programming or engineering that's worth asking (unless you're interviewing a new graduate with no internship experience)." I don't agree. I've had a bunch of people in for interview who looked great on paper but couldn't answer even some pretty basic questions about fundamental commonplace technologies. We didn't even get as far as fit, though that is of course also important. I'm happy to hear that you were qualified for the roles you applied for, but this is definitely not the case for all candidates.
              – Lightness Races in Orbit
              13 hours ago




              "There are so many basically competent people out there that there is nothing about programming or engineering that's worth asking (unless you're interviewing a new graduate with no internship experience)." I don't agree. I've had a bunch of people in for interview who looked great on paper but couldn't answer even some pretty basic questions about fundamental commonplace technologies. We didn't even get as far as fit, though that is of course also important. I'm happy to hear that you were qualified for the roles you applied for, but this is definitely not the case for all candidates.
              – Lightness Races in Orbit
              13 hours ago




              1




              1




              Right, this is not the case with software. Almost all "programmers" are barely competent, have a self-taught hobbyist vibe, and can't actually do anything. The OP is perfectly correct that folks drill to answer "interview type questions" you can look up online. The QA is about how to solve this problem.
              – Fattie
              7 hours ago




              Right, this is not the case with software. Almost all "programmers" are barely competent, have a self-taught hobbyist vibe, and can't actually do anything. The OP is perfectly correct that folks drill to answer "interview type questions" you can look up online. The QA is about how to solve this problem.
              – Fattie
              7 hours ago












              And if you need highly competent people there are not as many as there are needed.
              – Thorbjørn Ravn Andersen
              35 mins ago




              And if you need highly competent people there are not as many as there are needed.
              – Thorbjørn Ravn Andersen
              35 mins ago











              6














              Use Whiteboard interviews, and ask problems which are related to the skills and business domain that you're interested in. Look for people that you can work with, even if they aren't perfect matches for the position, because you can always train the right person if they have potential. Ask existing employees for recommendations (and offer a finders-fee)






              share|improve this answer

















              • 4




                Pete, I fear that OP is indeed talking about whiteboard-type problems!
                – Fattie
                20 hours ago






              • 3




                @Fattie - Yep - but a good thing with whiteboard interviews rather than take-away coding tests is that you can change the parameters halfway through the question to throw a spanner in the works
                – PeteCon
                20 hours ago






              • 8




                Don't ask people to code on a whiteboard! That's cruel!
                – Lightness Races in Orbit
                14 hours ago






              • 2




                These whiteboards interview are exactly the thing that got lots of books printed to go through them. As a developer, I like spending my time into actually learning my job and executing it, but my job is not writing programs on a whiteboard.
                – Pac0
                13 hours ago








              • 1




                @LightnessRacesinOrbit I disagree. Now, demanding that the code they write on the whiteboard compiles, that would be cruel. But writing some pseudo code is, IMO, a good way to get an impression of the coding abilities of a candidate, given the limited amount of time you have during an interview.
                – Abigail
                3 hours ago
















              6














              Use Whiteboard interviews, and ask problems which are related to the skills and business domain that you're interested in. Look for people that you can work with, even if they aren't perfect matches for the position, because you can always train the right person if they have potential. Ask existing employees for recommendations (and offer a finders-fee)






              share|improve this answer

















              • 4




                Pete, I fear that OP is indeed talking about whiteboard-type problems!
                – Fattie
                20 hours ago






              • 3




                @Fattie - Yep - but a good thing with whiteboard interviews rather than take-away coding tests is that you can change the parameters halfway through the question to throw a spanner in the works
                – PeteCon
                20 hours ago






              • 8




                Don't ask people to code on a whiteboard! That's cruel!
                – Lightness Races in Orbit
                14 hours ago






              • 2




                These whiteboards interview are exactly the thing that got lots of books printed to go through them. As a developer, I like spending my time into actually learning my job and executing it, but my job is not writing programs on a whiteboard.
                – Pac0
                13 hours ago








              • 1




                @LightnessRacesinOrbit I disagree. Now, demanding that the code they write on the whiteboard compiles, that would be cruel. But writing some pseudo code is, IMO, a good way to get an impression of the coding abilities of a candidate, given the limited amount of time you have during an interview.
                – Abigail
                3 hours ago














              6












              6








              6






              Use Whiteboard interviews, and ask problems which are related to the skills and business domain that you're interested in. Look for people that you can work with, even if they aren't perfect matches for the position, because you can always train the right person if they have potential. Ask existing employees for recommendations (and offer a finders-fee)






              share|improve this answer












              Use Whiteboard interviews, and ask problems which are related to the skills and business domain that you're interested in. Look for people that you can work with, even if they aren't perfect matches for the position, because you can always train the right person if they have potential. Ask existing employees for recommendations (and offer a finders-fee)







              share|improve this answer












              share|improve this answer



              share|improve this answer










              answered 20 hours ago









              PeteCon

              14.2k43858




              14.2k43858








              • 4




                Pete, I fear that OP is indeed talking about whiteboard-type problems!
                – Fattie
                20 hours ago






              • 3




                @Fattie - Yep - but a good thing with whiteboard interviews rather than take-away coding tests is that you can change the parameters halfway through the question to throw a spanner in the works
                – PeteCon
                20 hours ago






              • 8




                Don't ask people to code on a whiteboard! That's cruel!
                – Lightness Races in Orbit
                14 hours ago






              • 2




                These whiteboards interview are exactly the thing that got lots of books printed to go through them. As a developer, I like spending my time into actually learning my job and executing it, but my job is not writing programs on a whiteboard.
                – Pac0
                13 hours ago








              • 1




                @LightnessRacesinOrbit I disagree. Now, demanding that the code they write on the whiteboard compiles, that would be cruel. But writing some pseudo code is, IMO, a good way to get an impression of the coding abilities of a candidate, given the limited amount of time you have during an interview.
                – Abigail
                3 hours ago














              • 4




                Pete, I fear that OP is indeed talking about whiteboard-type problems!
                – Fattie
                20 hours ago






              • 3




                @Fattie - Yep - but a good thing with whiteboard interviews rather than take-away coding tests is that you can change the parameters halfway through the question to throw a spanner in the works
                – PeteCon
                20 hours ago






              • 8




                Don't ask people to code on a whiteboard! That's cruel!
                – Lightness Races in Orbit
                14 hours ago






              • 2




                These whiteboards interview are exactly the thing that got lots of books printed to go through them. As a developer, I like spending my time into actually learning my job and executing it, but my job is not writing programs on a whiteboard.
                – Pac0
                13 hours ago








              • 1




                @LightnessRacesinOrbit I disagree. Now, demanding that the code they write on the whiteboard compiles, that would be cruel. But writing some pseudo code is, IMO, a good way to get an impression of the coding abilities of a candidate, given the limited amount of time you have during an interview.
                – Abigail
                3 hours ago








              4




              4




              Pete, I fear that OP is indeed talking about whiteboard-type problems!
              – Fattie
              20 hours ago




              Pete, I fear that OP is indeed talking about whiteboard-type problems!
              – Fattie
              20 hours ago




              3




              3




              @Fattie - Yep - but a good thing with whiteboard interviews rather than take-away coding tests is that you can change the parameters halfway through the question to throw a spanner in the works
              – PeteCon
              20 hours ago




              @Fattie - Yep - but a good thing with whiteboard interviews rather than take-away coding tests is that you can change the parameters halfway through the question to throw a spanner in the works
              – PeteCon
              20 hours ago




              8




              8




              Don't ask people to code on a whiteboard! That's cruel!
              – Lightness Races in Orbit
              14 hours ago




              Don't ask people to code on a whiteboard! That's cruel!
              – Lightness Races in Orbit
              14 hours ago




              2




              2




              These whiteboards interview are exactly the thing that got lots of books printed to go through them. As a developer, I like spending my time into actually learning my job and executing it, but my job is not writing programs on a whiteboard.
              – Pac0
              13 hours ago






              These whiteboards interview are exactly the thing that got lots of books printed to go through them. As a developer, I like spending my time into actually learning my job and executing it, but my job is not writing programs on a whiteboard.
              – Pac0
              13 hours ago






              1




              1




              @LightnessRacesinOrbit I disagree. Now, demanding that the code they write on the whiteboard compiles, that would be cruel. But writing some pseudo code is, IMO, a good way to get an impression of the coding abilities of a candidate, given the limited amount of time you have during an interview.
              – Abigail
              3 hours ago




              @LightnessRacesinOrbit I disagree. Now, demanding that the code they write on the whiteboard compiles, that would be cruel. But writing some pseudo code is, IMO, a good way to get an impression of the coding abilities of a candidate, given the limited amount of time you have during an interview.
              – Abigail
              3 hours ago











              5














              After getting through enough basic questions to show that they have some minimal (by my needs) ability to write code, I move on to the tougher part of the interview, based on two subject areas, their work and my work.



              Ask for information about a recent project at their current job. Even with respect to NDAs and IP restrictions, they should be able to explain the business problem, the complexity of the problems and how they overcame them. If they can't explain their own work to me so that I can understand and evaluate, then I worry about how successful they will be.



              Ask them to white board a design/solution to one of your current problems. The expectation should not be a working solution but how they approach the problem. Provide enough information that they have a high level scope for the problem. They should ask good questions, and you should provide good answers so they can proceed. They should be able to sketch out some sort of solution. In the end their solution may not work out, but you will be able to see how they work on a problem and whether or not they should be able to work on the projects you will have.






              share|improve this answer


























                5














                After getting through enough basic questions to show that they have some minimal (by my needs) ability to write code, I move on to the tougher part of the interview, based on two subject areas, their work and my work.



                Ask for information about a recent project at their current job. Even with respect to NDAs and IP restrictions, they should be able to explain the business problem, the complexity of the problems and how they overcame them. If they can't explain their own work to me so that I can understand and evaluate, then I worry about how successful they will be.



                Ask them to white board a design/solution to one of your current problems. The expectation should not be a working solution but how they approach the problem. Provide enough information that they have a high level scope for the problem. They should ask good questions, and you should provide good answers so they can proceed. They should be able to sketch out some sort of solution. In the end their solution may not work out, but you will be able to see how they work on a problem and whether or not they should be able to work on the projects you will have.






                share|improve this answer
























                  5












                  5








                  5






                  After getting through enough basic questions to show that they have some minimal (by my needs) ability to write code, I move on to the tougher part of the interview, based on two subject areas, their work and my work.



                  Ask for information about a recent project at their current job. Even with respect to NDAs and IP restrictions, they should be able to explain the business problem, the complexity of the problems and how they overcame them. If they can't explain their own work to me so that I can understand and evaluate, then I worry about how successful they will be.



                  Ask them to white board a design/solution to one of your current problems. The expectation should not be a working solution but how they approach the problem. Provide enough information that they have a high level scope for the problem. They should ask good questions, and you should provide good answers so they can proceed. They should be able to sketch out some sort of solution. In the end their solution may not work out, but you will be able to see how they work on a problem and whether or not they should be able to work on the projects you will have.






                  share|improve this answer












                  After getting through enough basic questions to show that they have some minimal (by my needs) ability to write code, I move on to the tougher part of the interview, based on two subject areas, their work and my work.



                  Ask for information about a recent project at their current job. Even with respect to NDAs and IP restrictions, they should be able to explain the business problem, the complexity of the problems and how they overcame them. If they can't explain their own work to me so that I can understand and evaluate, then I worry about how successful they will be.



                  Ask them to white board a design/solution to one of your current problems. The expectation should not be a working solution but how they approach the problem. Provide enough information that they have a high level scope for the problem. They should ask good questions, and you should provide good answers so they can proceed. They should be able to sketch out some sort of solution. In the end their solution may not work out, but you will be able to see how they work on a problem and whether or not they should be able to work on the projects you will have.







                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered 19 hours ago









                  cdkMoose

                  10.5k22146




                  10.5k22146























                      4














                      About a year ago I started to have discussions with candidates. There are many topics that are controversial in the industry – for example:




                      • What framework is the best?

                      • Is a certain design pattern actually useful?

                      • Focus on new features or fix bugs first?


                      First I ask the candidates about their opinion. Once they got their point across I simply pick the opposite and argue against it. The following discussion will tell me a lot.




                      • Did they only memorize some facts for the interview or do they actually have experience with this area and good examples to prove their point? Actually, I was very surprised by how often their argument is: because I always did it that way

                      • How well are they able to bring their arguments and the complex technical details across? Are they good in teaching?

                      • How do they handle resistance? Do they try to convince, do they try to please or do they start to be aggressive or arrogant? Are they open to learning?


                      I am aware that this might be very stressful for the candidate. Therefore the has to be done very carefully.






                      share|improve this answer


























                        4














                        About a year ago I started to have discussions with candidates. There are many topics that are controversial in the industry – for example:




                        • What framework is the best?

                        • Is a certain design pattern actually useful?

                        • Focus on new features or fix bugs first?


                        First I ask the candidates about their opinion. Once they got their point across I simply pick the opposite and argue against it. The following discussion will tell me a lot.




                        • Did they only memorize some facts for the interview or do they actually have experience with this area and good examples to prove their point? Actually, I was very surprised by how often their argument is: because I always did it that way

                        • How well are they able to bring their arguments and the complex technical details across? Are they good in teaching?

                        • How do they handle resistance? Do they try to convince, do they try to please or do they start to be aggressive or arrogant? Are they open to learning?


                        I am aware that this might be very stressful for the candidate. Therefore the has to be done very carefully.






                        share|improve this answer
























                          4












                          4








                          4






                          About a year ago I started to have discussions with candidates. There are many topics that are controversial in the industry – for example:




                          • What framework is the best?

                          • Is a certain design pattern actually useful?

                          • Focus on new features or fix bugs first?


                          First I ask the candidates about their opinion. Once they got their point across I simply pick the opposite and argue against it. The following discussion will tell me a lot.




                          • Did they only memorize some facts for the interview or do they actually have experience with this area and good examples to prove their point? Actually, I was very surprised by how often their argument is: because I always did it that way

                          • How well are they able to bring their arguments and the complex technical details across? Are they good in teaching?

                          • How do they handle resistance? Do they try to convince, do they try to please or do they start to be aggressive or arrogant? Are they open to learning?


                          I am aware that this might be very stressful for the candidate. Therefore the has to be done very carefully.






                          share|improve this answer












                          About a year ago I started to have discussions with candidates. There are many topics that are controversial in the industry – for example:




                          • What framework is the best?

                          • Is a certain design pattern actually useful?

                          • Focus on new features or fix bugs first?


                          First I ask the candidates about their opinion. Once they got their point across I simply pick the opposite and argue against it. The following discussion will tell me a lot.




                          • Did they only memorize some facts for the interview or do they actually have experience with this area and good examples to prove their point? Actually, I was very surprised by how often their argument is: because I always did it that way

                          • How well are they able to bring their arguments and the complex technical details across? Are they good in teaching?

                          • How do they handle resistance? Do they try to convince, do they try to please or do they start to be aggressive or arrogant? Are they open to learning?


                          I am aware that this might be very stressful for the candidate. Therefore the has to be done very carefully.







                          share|improve this answer












                          share|improve this answer



                          share|improve this answer










                          answered 6 hours ago









                          spickermann

                          20114




                          20114























                              3














                              Simply. You just grill the applicants on the implementation details and change requirements on them to see how they respond. Make them use what they've memorized as building blocks.



                              To be frank, problem memorizing isn't an issue. Memorization is actually one of the key techniques chess players use to learn the game. By memorizing algorithms your applicants are developing a library of solutions from which to work from. This means that they'll be able to solve problems better in the future, if the patterns and implementation of the patterns they're learning are actually useful.



                              What you need to test is that last part. By varying the problem in real time you get to see how well the applicant actually understands how to use what they've memorized. This means that you can ask them about better ways to solve the question and you can even ask them to compose their solution into a work flow to do something completely different.



                              What you want is someone who can solve problems. What you don't want is someone who solves problems the way you want to see them solved. If everyone's memorizing solutions, all you need to do is test their ability to use what they've memorized. When it comes down to it, everyone uses what they know to break down what they don't know. If your devs can use patterns they've already mastered to break down problems of increasing complexity, then they would have been able to reverse a linked list if they've never seen anyone do it before.



                              As a recruiter, this is as far as you can reasonably be expected to go without trying to get free labor out of your applicants.






                              share|improve this answer





















                              • It's funny you mention reversing a linked list. I expect that's the type of question OP is complaining about. Personally, I go even more basic than that. I ask what data structures they have used in their favorite language, e.g. in Python, there is a list and a deque. I would ask about differing performance characteristics between them for operations . They may have this memorized but not understand that a list is backed by an array whereas a deque is backed by a linked list. So despite their ability to reverse a linked list, they don't really understand why you use linked lists.
                                – Chan-Ho Suh
                                14 hours ago
















                              3














                              Simply. You just grill the applicants on the implementation details and change requirements on them to see how they respond. Make them use what they've memorized as building blocks.



                              To be frank, problem memorizing isn't an issue. Memorization is actually one of the key techniques chess players use to learn the game. By memorizing algorithms your applicants are developing a library of solutions from which to work from. This means that they'll be able to solve problems better in the future, if the patterns and implementation of the patterns they're learning are actually useful.



                              What you need to test is that last part. By varying the problem in real time you get to see how well the applicant actually understands how to use what they've memorized. This means that you can ask them about better ways to solve the question and you can even ask them to compose their solution into a work flow to do something completely different.



                              What you want is someone who can solve problems. What you don't want is someone who solves problems the way you want to see them solved. If everyone's memorizing solutions, all you need to do is test their ability to use what they've memorized. When it comes down to it, everyone uses what they know to break down what they don't know. If your devs can use patterns they've already mastered to break down problems of increasing complexity, then they would have been able to reverse a linked list if they've never seen anyone do it before.



                              As a recruiter, this is as far as you can reasonably be expected to go without trying to get free labor out of your applicants.






                              share|improve this answer





















                              • It's funny you mention reversing a linked list. I expect that's the type of question OP is complaining about. Personally, I go even more basic than that. I ask what data structures they have used in their favorite language, e.g. in Python, there is a list and a deque. I would ask about differing performance characteristics between them for operations . They may have this memorized but not understand that a list is backed by an array whereas a deque is backed by a linked list. So despite their ability to reverse a linked list, they don't really understand why you use linked lists.
                                – Chan-Ho Suh
                                14 hours ago














                              3












                              3








                              3






                              Simply. You just grill the applicants on the implementation details and change requirements on them to see how they respond. Make them use what they've memorized as building blocks.



                              To be frank, problem memorizing isn't an issue. Memorization is actually one of the key techniques chess players use to learn the game. By memorizing algorithms your applicants are developing a library of solutions from which to work from. This means that they'll be able to solve problems better in the future, if the patterns and implementation of the patterns they're learning are actually useful.



                              What you need to test is that last part. By varying the problem in real time you get to see how well the applicant actually understands how to use what they've memorized. This means that you can ask them about better ways to solve the question and you can even ask them to compose their solution into a work flow to do something completely different.



                              What you want is someone who can solve problems. What you don't want is someone who solves problems the way you want to see them solved. If everyone's memorizing solutions, all you need to do is test their ability to use what they've memorized. When it comes down to it, everyone uses what they know to break down what they don't know. If your devs can use patterns they've already mastered to break down problems of increasing complexity, then they would have been able to reverse a linked list if they've never seen anyone do it before.



                              As a recruiter, this is as far as you can reasonably be expected to go without trying to get free labor out of your applicants.






                              share|improve this answer












                              Simply. You just grill the applicants on the implementation details and change requirements on them to see how they respond. Make them use what they've memorized as building blocks.



                              To be frank, problem memorizing isn't an issue. Memorization is actually one of the key techniques chess players use to learn the game. By memorizing algorithms your applicants are developing a library of solutions from which to work from. This means that they'll be able to solve problems better in the future, if the patterns and implementation of the patterns they're learning are actually useful.



                              What you need to test is that last part. By varying the problem in real time you get to see how well the applicant actually understands how to use what they've memorized. This means that you can ask them about better ways to solve the question and you can even ask them to compose their solution into a work flow to do something completely different.



                              What you want is someone who can solve problems. What you don't want is someone who solves problems the way you want to see them solved. If everyone's memorizing solutions, all you need to do is test their ability to use what they've memorized. When it comes down to it, everyone uses what they know to break down what they don't know. If your devs can use patterns they've already mastered to break down problems of increasing complexity, then they would have been able to reverse a linked list if they've never seen anyone do it before.



                              As a recruiter, this is as far as you can reasonably be expected to go without trying to get free labor out of your applicants.







                              share|improve this answer












                              share|improve this answer



                              share|improve this answer










                              answered 16 hours ago









                              Steve

                              2,005416




                              2,005416












                              • It's funny you mention reversing a linked list. I expect that's the type of question OP is complaining about. Personally, I go even more basic than that. I ask what data structures they have used in their favorite language, e.g. in Python, there is a list and a deque. I would ask about differing performance characteristics between them for operations . They may have this memorized but not understand that a list is backed by an array whereas a deque is backed by a linked list. So despite their ability to reverse a linked list, they don't really understand why you use linked lists.
                                – Chan-Ho Suh
                                14 hours ago


















                              • It's funny you mention reversing a linked list. I expect that's the type of question OP is complaining about. Personally, I go even more basic than that. I ask what data structures they have used in their favorite language, e.g. in Python, there is a list and a deque. I would ask about differing performance characteristics between them for operations . They may have this memorized but not understand that a list is backed by an array whereas a deque is backed by a linked list. So despite their ability to reverse a linked list, they don't really understand why you use linked lists.
                                – Chan-Ho Suh
                                14 hours ago
















                              It's funny you mention reversing a linked list. I expect that's the type of question OP is complaining about. Personally, I go even more basic than that. I ask what data structures they have used in their favorite language, e.g. in Python, there is a list and a deque. I would ask about differing performance characteristics between them for operations . They may have this memorized but not understand that a list is backed by an array whereas a deque is backed by a linked list. So despite their ability to reverse a linked list, they don't really understand why you use linked lists.
                              – Chan-Ho Suh
                              14 hours ago




                              It's funny you mention reversing a linked list. I expect that's the type of question OP is complaining about. Personally, I go even more basic than that. I ask what data structures they have used in their favorite language, e.g. in Python, there is a list and a deque. I would ask about differing performance characteristics between them for operations . They may have this memorized but not understand that a list is backed by an array whereas a deque is backed by a linked list. So despite their ability to reverse a linked list, they don't really understand why you use linked lists.
                              – Chan-Ho Suh
                              14 hours ago











                              2














                              In some ways, studying for the interview is a good thing. You probably already ask that people study about four years in a University to prepare for the interview.



                              Now, if your interviewing process is scripted, and the script lacks any kind of variation, then it is just a matter of time before the answers become memorized in the population. Solutions include:




                              1. As questions that are generated, with variable fields that require the work to be done specific to this asking of the question.

                              2. Change the question set from time to time, to minimize the time to build the pool of answers.

                              3. Change the entire approach, giving them a trivial project with specifically added bugs, asking them to fix it and add a known feature.


                              Also, consider the problem in the larger sense, if you are asking for information in an interview, and the information was memorized, then that should be an ideal candidate, unless you are asking for the wrong information.



                              You are deciding that the information isn't what is wanted, so you might be able to fix the problem by asking for the right kind of information.






                              share|improve this answer


























                                2














                                In some ways, studying for the interview is a good thing. You probably already ask that people study about four years in a University to prepare for the interview.



                                Now, if your interviewing process is scripted, and the script lacks any kind of variation, then it is just a matter of time before the answers become memorized in the population. Solutions include:




                                1. As questions that are generated, with variable fields that require the work to be done specific to this asking of the question.

                                2. Change the question set from time to time, to minimize the time to build the pool of answers.

                                3. Change the entire approach, giving them a trivial project with specifically added bugs, asking them to fix it and add a known feature.


                                Also, consider the problem in the larger sense, if you are asking for information in an interview, and the information was memorized, then that should be an ideal candidate, unless you are asking for the wrong information.



                                You are deciding that the information isn't what is wanted, so you might be able to fix the problem by asking for the right kind of information.






                                share|improve this answer
























                                  2












                                  2








                                  2






                                  In some ways, studying for the interview is a good thing. You probably already ask that people study about four years in a University to prepare for the interview.



                                  Now, if your interviewing process is scripted, and the script lacks any kind of variation, then it is just a matter of time before the answers become memorized in the population. Solutions include:




                                  1. As questions that are generated, with variable fields that require the work to be done specific to this asking of the question.

                                  2. Change the question set from time to time, to minimize the time to build the pool of answers.

                                  3. Change the entire approach, giving them a trivial project with specifically added bugs, asking them to fix it and add a known feature.


                                  Also, consider the problem in the larger sense, if you are asking for information in an interview, and the information was memorized, then that should be an ideal candidate, unless you are asking for the wrong information.



                                  You are deciding that the information isn't what is wanted, so you might be able to fix the problem by asking for the right kind of information.






                                  share|improve this answer












                                  In some ways, studying for the interview is a good thing. You probably already ask that people study about four years in a University to prepare for the interview.



                                  Now, if your interviewing process is scripted, and the script lacks any kind of variation, then it is just a matter of time before the answers become memorized in the population. Solutions include:




                                  1. As questions that are generated, with variable fields that require the work to be done specific to this asking of the question.

                                  2. Change the question set from time to time, to minimize the time to build the pool of answers.

                                  3. Change the entire approach, giving them a trivial project with specifically added bugs, asking them to fix it and add a known feature.


                                  Also, consider the problem in the larger sense, if you are asking for information in an interview, and the information was memorized, then that should be an ideal candidate, unless you are asking for the wrong information.



                                  You are deciding that the information isn't what is wanted, so you might be able to fix the problem by asking for the right kind of information.







                                  share|improve this answer












                                  share|improve this answer



                                  share|improve this answer










                                  answered 19 hours ago









                                  Edwin Buck

                                  2,5231019




                                  2,5231019























                                      2














                                      I believe you misunderstand the reason why big companies ask algorithm questions. Writing out the algorithm for quicksort is probably not a very useful skill for the majority of developers. Likewise figuring out the best way to parse a 1 million character string is not something people routinely do at work. However knowing how to solve these problems is a great way of filtering out the dumb candidates. If someone is too dumb for the job, they won't be able to coherently answer any of the interviewing puzzles commonly asked at job interviews. Even if they memorize all the answers, you could easily break their pattern by asking a slightly different variation of the question or adding a bonus question on the spot. In contrast, a good candidate would have no issues preparing for the "test" and would pass with flying colors.



                                      Interviewing is about filtering out the bad candidates, rather than about finding the best candidates per se. There's no harm in having someone prepare in advance, as this wouldn't help someone who's not prepared to work on the right level.






                                      share|improve this answer





















                                      • This is quite true. "interview tech questions" are just a filter. (like having "a reasonably professional CV" is a filter.)
                                        – Fattie
                                        7 hours ago
















                                      2














                                      I believe you misunderstand the reason why big companies ask algorithm questions. Writing out the algorithm for quicksort is probably not a very useful skill for the majority of developers. Likewise figuring out the best way to parse a 1 million character string is not something people routinely do at work. However knowing how to solve these problems is a great way of filtering out the dumb candidates. If someone is too dumb for the job, they won't be able to coherently answer any of the interviewing puzzles commonly asked at job interviews. Even if they memorize all the answers, you could easily break their pattern by asking a slightly different variation of the question or adding a bonus question on the spot. In contrast, a good candidate would have no issues preparing for the "test" and would pass with flying colors.



                                      Interviewing is about filtering out the bad candidates, rather than about finding the best candidates per se. There's no harm in having someone prepare in advance, as this wouldn't help someone who's not prepared to work on the right level.






                                      share|improve this answer





















                                      • This is quite true. "interview tech questions" are just a filter. (like having "a reasonably professional CV" is a filter.)
                                        – Fattie
                                        7 hours ago














                                      2












                                      2








                                      2






                                      I believe you misunderstand the reason why big companies ask algorithm questions. Writing out the algorithm for quicksort is probably not a very useful skill for the majority of developers. Likewise figuring out the best way to parse a 1 million character string is not something people routinely do at work. However knowing how to solve these problems is a great way of filtering out the dumb candidates. If someone is too dumb for the job, they won't be able to coherently answer any of the interviewing puzzles commonly asked at job interviews. Even if they memorize all the answers, you could easily break their pattern by asking a slightly different variation of the question or adding a bonus question on the spot. In contrast, a good candidate would have no issues preparing for the "test" and would pass with flying colors.



                                      Interviewing is about filtering out the bad candidates, rather than about finding the best candidates per se. There's no harm in having someone prepare in advance, as this wouldn't help someone who's not prepared to work on the right level.






                                      share|improve this answer












                                      I believe you misunderstand the reason why big companies ask algorithm questions. Writing out the algorithm for quicksort is probably not a very useful skill for the majority of developers. Likewise figuring out the best way to parse a 1 million character string is not something people routinely do at work. However knowing how to solve these problems is a great way of filtering out the dumb candidates. If someone is too dumb for the job, they won't be able to coherently answer any of the interviewing puzzles commonly asked at job interviews. Even if they memorize all the answers, you could easily break their pattern by asking a slightly different variation of the question or adding a bonus question on the spot. In contrast, a good candidate would have no issues preparing for the "test" and would pass with flying colors.



                                      Interviewing is about filtering out the bad candidates, rather than about finding the best candidates per se. There's no harm in having someone prepare in advance, as this wouldn't help someone who's not prepared to work on the right level.







                                      share|improve this answer












                                      share|improve this answer



                                      share|improve this answer










                                      answered 10 hours ago









                                      JonathanReez

                                      15417




                                      15417












                                      • This is quite true. "interview tech questions" are just a filter. (like having "a reasonably professional CV" is a filter.)
                                        – Fattie
                                        7 hours ago


















                                      • This is quite true. "interview tech questions" are just a filter. (like having "a reasonably professional CV" is a filter.)
                                        – Fattie
                                        7 hours ago
















                                      This is quite true. "interview tech questions" are just a filter. (like having "a reasonably professional CV" is a filter.)
                                      – Fattie
                                      7 hours ago




                                      This is quite true. "interview tech questions" are just a filter. (like having "a reasonably professional CV" is a filter.)
                                      – Fattie
                                      7 hours ago











                                      1














                                      If your candidates are able to pass your interviews by studying, isn't that a strong indication of their ability to study and learn? If you're hiring fresh grads, that's really the most valuable skill to hire for.



                                      If an experienced candidate is doing it, at the very minimum it means they're highly motivated to study for your interview. Which means they're strongly interested in coming to work for your company. And also, it's a strong signal that they haven't lost their ability to learn and grind after leaving college. You should still ask them questions about their work experience, achievements, and collaborations with co-workers to get a better sense of their overall ability.




                                      It's problem-solvers that we want, not problem-memorizers.




                                      Very few people can come up with quicksort, or Floyd's cycle detection algorithm, or finding the longest increasing subsequence in the timespan of an interview having never studied the solution. Those who can are unlikely to be interviewing at your company for regular dev jobs. No offense, I'm sure it's a great company, but statistically most of your candidates are not going to be of that caliber - because very few programmers in the world are.



                                      On the other hand, if your candidates are able to apply solutions to problems they've seen before to variations of that problem or to related problems, it's a signal that they're good at pattern-matching and identifying what type of problem they're looking at. Conversely, if they've never seen that type of problem before you also have signal that they know how to research a solution and understand it - because after all, they studied for, and passed your interview.






                                      share|improve this answer

















                                      • 1




                                        The thing is, you shouldn't have a test that can be aced by memorizing what can be quickly looked up, because such memorization is not a useful job skill. Rather, you should have a test/question that requires the kinds of thinking necessary on the job that a search engine can't help with, or at least requires using it in a clever and inventive way.
                                        – Chris Stratton
                                        9 hours ago


















                                      1














                                      If your candidates are able to pass your interviews by studying, isn't that a strong indication of their ability to study and learn? If you're hiring fresh grads, that's really the most valuable skill to hire for.



                                      If an experienced candidate is doing it, at the very minimum it means they're highly motivated to study for your interview. Which means they're strongly interested in coming to work for your company. And also, it's a strong signal that they haven't lost their ability to learn and grind after leaving college. You should still ask them questions about their work experience, achievements, and collaborations with co-workers to get a better sense of their overall ability.




                                      It's problem-solvers that we want, not problem-memorizers.




                                      Very few people can come up with quicksort, or Floyd's cycle detection algorithm, or finding the longest increasing subsequence in the timespan of an interview having never studied the solution. Those who can are unlikely to be interviewing at your company for regular dev jobs. No offense, I'm sure it's a great company, but statistically most of your candidates are not going to be of that caliber - because very few programmers in the world are.



                                      On the other hand, if your candidates are able to apply solutions to problems they've seen before to variations of that problem or to related problems, it's a signal that they're good at pattern-matching and identifying what type of problem they're looking at. Conversely, if they've never seen that type of problem before you also have signal that they know how to research a solution and understand it - because after all, they studied for, and passed your interview.






                                      share|improve this answer

















                                      • 1




                                        The thing is, you shouldn't have a test that can be aced by memorizing what can be quickly looked up, because such memorization is not a useful job skill. Rather, you should have a test/question that requires the kinds of thinking necessary on the job that a search engine can't help with, or at least requires using it in a clever and inventive way.
                                        – Chris Stratton
                                        9 hours ago
















                                      1












                                      1








                                      1






                                      If your candidates are able to pass your interviews by studying, isn't that a strong indication of their ability to study and learn? If you're hiring fresh grads, that's really the most valuable skill to hire for.



                                      If an experienced candidate is doing it, at the very minimum it means they're highly motivated to study for your interview. Which means they're strongly interested in coming to work for your company. And also, it's a strong signal that they haven't lost their ability to learn and grind after leaving college. You should still ask them questions about their work experience, achievements, and collaborations with co-workers to get a better sense of their overall ability.




                                      It's problem-solvers that we want, not problem-memorizers.




                                      Very few people can come up with quicksort, or Floyd's cycle detection algorithm, or finding the longest increasing subsequence in the timespan of an interview having never studied the solution. Those who can are unlikely to be interviewing at your company for regular dev jobs. No offense, I'm sure it's a great company, but statistically most of your candidates are not going to be of that caliber - because very few programmers in the world are.



                                      On the other hand, if your candidates are able to apply solutions to problems they've seen before to variations of that problem or to related problems, it's a signal that they're good at pattern-matching and identifying what type of problem they're looking at. Conversely, if they've never seen that type of problem before you also have signal that they know how to research a solution and understand it - because after all, they studied for, and passed your interview.






                                      share|improve this answer












                                      If your candidates are able to pass your interviews by studying, isn't that a strong indication of their ability to study and learn? If you're hiring fresh grads, that's really the most valuable skill to hire for.



                                      If an experienced candidate is doing it, at the very minimum it means they're highly motivated to study for your interview. Which means they're strongly interested in coming to work for your company. And also, it's a strong signal that they haven't lost their ability to learn and grind after leaving college. You should still ask them questions about their work experience, achievements, and collaborations with co-workers to get a better sense of their overall ability.




                                      It's problem-solvers that we want, not problem-memorizers.




                                      Very few people can come up with quicksort, or Floyd's cycle detection algorithm, or finding the longest increasing subsequence in the timespan of an interview having never studied the solution. Those who can are unlikely to be interviewing at your company for regular dev jobs. No offense, I'm sure it's a great company, but statistically most of your candidates are not going to be of that caliber - because very few programmers in the world are.



                                      On the other hand, if your candidates are able to apply solutions to problems they've seen before to variations of that problem or to related problems, it's a signal that they're good at pattern-matching and identifying what type of problem they're looking at. Conversely, if they've never seen that type of problem before you also have signal that they know how to research a solution and understand it - because after all, they studied for, and passed your interview.







                                      share|improve this answer












                                      share|improve this answer



                                      share|improve this answer










                                      answered 11 hours ago









                                      Jay

                                      1489




                                      1489








                                      • 1




                                        The thing is, you shouldn't have a test that can be aced by memorizing what can be quickly looked up, because such memorization is not a useful job skill. Rather, you should have a test/question that requires the kinds of thinking necessary on the job that a search engine can't help with, or at least requires using it in a clever and inventive way.
                                        – Chris Stratton
                                        9 hours ago
















                                      • 1




                                        The thing is, you shouldn't have a test that can be aced by memorizing what can be quickly looked up, because such memorization is not a useful job skill. Rather, you should have a test/question that requires the kinds of thinking necessary on the job that a search engine can't help with, or at least requires using it in a clever and inventive way.
                                        – Chris Stratton
                                        9 hours ago










                                      1




                                      1




                                      The thing is, you shouldn't have a test that can be aced by memorizing what can be quickly looked up, because such memorization is not a useful job skill. Rather, you should have a test/question that requires the kinds of thinking necessary on the job that a search engine can't help with, or at least requires using it in a clever and inventive way.
                                      – Chris Stratton
                                      9 hours ago






                                      The thing is, you shouldn't have a test that can be aced by memorizing what can be quickly looked up, because such memorization is not a useful job skill. Rather, you should have a test/question that requires the kinds of thinking necessary on the job that a search engine can't help with, or at least requires using it in a clever and inventive way.
                                      – Chris Stratton
                                      9 hours ago













                                      1














                                      Being able to come up with a solution on the spot isn't really that great a qualification, either, at least IMHO. I've certainly come up with a lot of on-the-spot solutions that in retrospect weren't all that great, and have sometimes spent weeks or months finding a decent solution to a really hard problem. (And sometimes the solution is just remembering that I saw something similar in a code example somewhere...)



                                      You don't say whether you're trying to hire new grads or experienced developers, but in either case I think you really have to find some way to look at what they've done previously. Sometimes it's looking at published papers (even if the person isn't the principal author), sometimes it's a personal recommendation, sometimes just asking them to show you something they've done that they're proud of. FWIW, I don't think I've ever gotten a job that I interviewed for that didn't have at least one of those things going for it.






                                      share|improve this answer


























                                        1














                                        Being able to come up with a solution on the spot isn't really that great a qualification, either, at least IMHO. I've certainly come up with a lot of on-the-spot solutions that in retrospect weren't all that great, and have sometimes spent weeks or months finding a decent solution to a really hard problem. (And sometimes the solution is just remembering that I saw something similar in a code example somewhere...)



                                        You don't say whether you're trying to hire new grads or experienced developers, but in either case I think you really have to find some way to look at what they've done previously. Sometimes it's looking at published papers (even if the person isn't the principal author), sometimes it's a personal recommendation, sometimes just asking them to show you something they've done that they're proud of. FWIW, I don't think I've ever gotten a job that I interviewed for that didn't have at least one of those things going for it.






                                        share|improve this answer
























                                          1












                                          1








                                          1






                                          Being able to come up with a solution on the spot isn't really that great a qualification, either, at least IMHO. I've certainly come up with a lot of on-the-spot solutions that in retrospect weren't all that great, and have sometimes spent weeks or months finding a decent solution to a really hard problem. (And sometimes the solution is just remembering that I saw something similar in a code example somewhere...)



                                          You don't say whether you're trying to hire new grads or experienced developers, but in either case I think you really have to find some way to look at what they've done previously. Sometimes it's looking at published papers (even if the person isn't the principal author), sometimes it's a personal recommendation, sometimes just asking them to show you something they've done that they're proud of. FWIW, I don't think I've ever gotten a job that I interviewed for that didn't have at least one of those things going for it.






                                          share|improve this answer












                                          Being able to come up with a solution on the spot isn't really that great a qualification, either, at least IMHO. I've certainly come up with a lot of on-the-spot solutions that in retrospect weren't all that great, and have sometimes spent weeks or months finding a decent solution to a really hard problem. (And sometimes the solution is just remembering that I saw something similar in a code example somewhere...)



                                          You don't say whether you're trying to hire new grads or experienced developers, but in either case I think you really have to find some way to look at what they've done previously. Sometimes it's looking at published papers (even if the person isn't the principal author), sometimes it's a personal recommendation, sometimes just asking them to show you something they've done that they're proud of. FWIW, I don't think I've ever gotten a job that I interviewed for that didn't have at least one of those things going for it.







                                          share|improve this answer












                                          share|improve this answer



                                          share|improve this answer










                                          answered 10 hours ago









                                          jamesqf

                                          82969




                                          82969























                                              1














                                              As an applicant, there are a few things I noticed which can still be tested during an interview, even if you're not in the IT field yourself:




                                              • Behaviour-based questions


                                              The objective is not to nail the person you have in front of you, but actually see what kind of person they might be. This gives a short window of whether or not they might be suited for working in the company.




                                              • Past experience questions



                                              [Could you] Tell me about a situation when...




                                              For this one, the objective is to invite the person into telling you more about their experience in a specific situation. This type of question can assert their skills as well as their self-being.



                                              It can be useful if you know the IT teams has some situations which can be difficult to handle (having to handle a lot of tasks in short notice, having to handle tired clients, etc).




                                              • Problem-solving based question


                                              You mentioned you are looking for problem-solver.



                                              I once had an interview with a company where the interviewers didn't ask any programming based question. In order to assert my problem-solving skills, they instead told me about a situation, and I was told to think aloud so they can witness my problem-solving skills in action. For example:




                                              We have a plane with 50 seats, and 50 passengers awaiting to come in. The first two passengers lost their cards, so they will sit in a random seat. The next passenger will sit in their seat if they can (if it's not already occupied); otherwise, they will sit in a random seat. What is the probability for the last passenger to sit in his own seat?




                                              The objective is not for them to find the solution, but to show you how they tackle the problem.



                                              ~~~~~~~~~~



                                              For each of these questions, remember to take note of the applicant's answer. This way, you can better discuss about them with the IT department manager.






                                              share|improve this answer


























                                                1














                                                As an applicant, there are a few things I noticed which can still be tested during an interview, even if you're not in the IT field yourself:




                                                • Behaviour-based questions


                                                The objective is not to nail the person you have in front of you, but actually see what kind of person they might be. This gives a short window of whether or not they might be suited for working in the company.




                                                • Past experience questions



                                                [Could you] Tell me about a situation when...




                                                For this one, the objective is to invite the person into telling you more about their experience in a specific situation. This type of question can assert their skills as well as their self-being.



                                                It can be useful if you know the IT teams has some situations which can be difficult to handle (having to handle a lot of tasks in short notice, having to handle tired clients, etc).




                                                • Problem-solving based question


                                                You mentioned you are looking for problem-solver.



                                                I once had an interview with a company where the interviewers didn't ask any programming based question. In order to assert my problem-solving skills, they instead told me about a situation, and I was told to think aloud so they can witness my problem-solving skills in action. For example:




                                                We have a plane with 50 seats, and 50 passengers awaiting to come in. The first two passengers lost their cards, so they will sit in a random seat. The next passenger will sit in their seat if they can (if it's not already occupied); otherwise, they will sit in a random seat. What is the probability for the last passenger to sit in his own seat?




                                                The objective is not for them to find the solution, but to show you how they tackle the problem.



                                                ~~~~~~~~~~



                                                For each of these questions, remember to take note of the applicant's answer. This way, you can better discuss about them with the IT department manager.






                                                share|improve this answer
























                                                  1












                                                  1








                                                  1






                                                  As an applicant, there are a few things I noticed which can still be tested during an interview, even if you're not in the IT field yourself:




                                                  • Behaviour-based questions


                                                  The objective is not to nail the person you have in front of you, but actually see what kind of person they might be. This gives a short window of whether or not they might be suited for working in the company.




                                                  • Past experience questions



                                                  [Could you] Tell me about a situation when...




                                                  For this one, the objective is to invite the person into telling you more about their experience in a specific situation. This type of question can assert their skills as well as their self-being.



                                                  It can be useful if you know the IT teams has some situations which can be difficult to handle (having to handle a lot of tasks in short notice, having to handle tired clients, etc).




                                                  • Problem-solving based question


                                                  You mentioned you are looking for problem-solver.



                                                  I once had an interview with a company where the interviewers didn't ask any programming based question. In order to assert my problem-solving skills, they instead told me about a situation, and I was told to think aloud so they can witness my problem-solving skills in action. For example:




                                                  We have a plane with 50 seats, and 50 passengers awaiting to come in. The first two passengers lost their cards, so they will sit in a random seat. The next passenger will sit in their seat if they can (if it's not already occupied); otherwise, they will sit in a random seat. What is the probability for the last passenger to sit in his own seat?




                                                  The objective is not for them to find the solution, but to show you how they tackle the problem.



                                                  ~~~~~~~~~~



                                                  For each of these questions, remember to take note of the applicant's answer. This way, you can better discuss about them with the IT department manager.






                                                  share|improve this answer












                                                  As an applicant, there are a few things I noticed which can still be tested during an interview, even if you're not in the IT field yourself:




                                                  • Behaviour-based questions


                                                  The objective is not to nail the person you have in front of you, but actually see what kind of person they might be. This gives a short window of whether or not they might be suited for working in the company.




                                                  • Past experience questions



                                                  [Could you] Tell me about a situation when...




                                                  For this one, the objective is to invite the person into telling you more about their experience in a specific situation. This type of question can assert their skills as well as their self-being.



                                                  It can be useful if you know the IT teams has some situations which can be difficult to handle (having to handle a lot of tasks in short notice, having to handle tired clients, etc).




                                                  • Problem-solving based question


                                                  You mentioned you are looking for problem-solver.



                                                  I once had an interview with a company where the interviewers didn't ask any programming based question. In order to assert my problem-solving skills, they instead told me about a situation, and I was told to think aloud so they can witness my problem-solving skills in action. For example:




                                                  We have a plane with 50 seats, and 50 passengers awaiting to come in. The first two passengers lost their cards, so they will sit in a random seat. The next passenger will sit in their seat if they can (if it's not already occupied); otherwise, they will sit in a random seat. What is the probability for the last passenger to sit in his own seat?




                                                  The objective is not for them to find the solution, but to show you how they tackle the problem.



                                                  ~~~~~~~~~~



                                                  For each of these questions, remember to take note of the applicant's answer. This way, you can better discuss about them with the IT department manager.







                                                  share|improve this answer












                                                  share|improve this answer



                                                  share|improve this answer










                                                  answered 5 hours ago









                                                  Clockwork

                                                  1548




                                                  1548























                                                      1














                                                      Welcome new user, I've come to believe that the only way to find software engineers is, once you've found someone who seems to know what they're talking about,




                                                      • Simply pay them for a one or two week freelance contract. Actually have them jump in and do a real project on your real product with the real team.


                                                      This is becoming more and more common.



                                                      I think that's it.



                                                      It's the only way to know.



                                                      Everything else is useless, as the OP points out.



                                                      The amount of time/money you'll spend on the sundry alternatives ... might as well just put them on the project for a week.



                                                      (Depending on your style and project, you might retain 'em for a time period (a week) or some "task" for $x. Either way.)



                                                      If you consistently take this approach, you'll find after a year or two that, the money you wasted doing this approach, was indeed far less than the sundry other costs of search and hiring.





                                                      Some further thoughts, the tenor of this QA is



                                                      • For software engineers, recruitment processes fail - indeed they're often "hopeless". (One apex of this, and the particular one raised in frustration by the OP, is that hopeful programmers now just "game" the "technical questions" phase of things.)



                                                      • Note that even "google-style" absurdly detailed/extended recruitment processes ............ often completely fail. Programmers (in particular) often "just don't work out" no matter how careful the recruitment processes.



                                                      • By all means in any industry or mode of occupation, folks sometimes "don't work out" even after careful recruitment. However, this is especially a problem for software engineers - it is notorious.



                                                      {You may ask - why? How come it's particularly a problem with programmers? I know precisely why this is, and some people have their own theories on it, but no need to start another argument!}





                                                      Even more thoughts!



                                                      This answer has a big pile of downvotes and a big pile of upvotes.



                                                      Apparently




                                                      • for many folks this is a totally obvious idea


                                                      • but for other folks it is freaky crazy stuff.



                                                      After all, setting aside just programming per se, back in the 90s one of the keys to the staggering success of General Electric at the time was Jack Welch's scheme where each manager simply fired the bottom 10% of people each year! (His book is terrific BTW.)



                                                      And I cringe to type the phrase "the gig economy" but in "the gig economy" we are all on "a trial basis" - from day to day and forever.



                                                      Winnowing programmers is incredibly, notoriously, difficult.






                                                      share|improve this answer



















                                                      • 13




                                                        Hopefully you mean as an off-hours contract project. Or as a final check after a meaningful selection process. Otherwise routinely making your selection only after bringing people onboard as employees is terrible for all concerned - it's expensive of both money and on-boarding effort, and it means often asking people to leave an existing job for a very uncertain alternative.
                                                        – Chris Stratton
                                                        19 hours ago






                                                      • 15




                                                        This may require that the candidate quit his or her current job to try out yours. This may not be bad if you want to hire from the unemployed only, but you're leaving some very promising people wondering "Why should I (quit my job/spend a full week of time off) just to interview?".
                                                        – David Thornley
                                                        17 hours ago






                                                      • 8




                                                        Do you tell your candidates what the process is up front? I would never accept a job offer that said "We don't want to rigorously interview you, we'll just let you work for us for a couple of weeks, and if you're not exactly what we're looking for, you're out the door". That is a huge risk to ask an employee to take, particularly if they have to quit their existing job first.
                                                        – asgallant
                                                        16 hours ago






                                                      • 6




                                                        In a lot of places this idea would be a breach of contract / employment law.
                                                        – Neuromancer
                                                        15 hours ago






                                                      • 4




                                                        What an awful idea.
                                                        – Lightness Races in Orbit
                                                        13 hours ago
















                                                      1














                                                      Welcome new user, I've come to believe that the only way to find software engineers is, once you've found someone who seems to know what they're talking about,




                                                      • Simply pay them for a one or two week freelance contract. Actually have them jump in and do a real project on your real product with the real team.


                                                      This is becoming more and more common.



                                                      I think that's it.



                                                      It's the only way to know.



                                                      Everything else is useless, as the OP points out.



                                                      The amount of time/money you'll spend on the sundry alternatives ... might as well just put them on the project for a week.



                                                      (Depending on your style and project, you might retain 'em for a time period (a week) or some "task" for $x. Either way.)



                                                      If you consistently take this approach, you'll find after a year or two that, the money you wasted doing this approach, was indeed far less than the sundry other costs of search and hiring.





                                                      Some further thoughts, the tenor of this QA is



                                                      • For software engineers, recruitment processes fail - indeed they're often "hopeless". (One apex of this, and the particular one raised in frustration by the OP, is that hopeful programmers now just "game" the "technical questions" phase of things.)



                                                      • Note that even "google-style" absurdly detailed/extended recruitment processes ............ often completely fail. Programmers (in particular) often "just don't work out" no matter how careful the recruitment processes.



                                                      • By all means in any industry or mode of occupation, folks sometimes "don't work out" even after careful recruitment. However, this is especially a problem for software engineers - it is notorious.



                                                      {You may ask - why? How come it's particularly a problem with programmers? I know precisely why this is, and some people have their own theories on it, but no need to start another argument!}





                                                      Even more thoughts!



                                                      This answer has a big pile of downvotes and a big pile of upvotes.



                                                      Apparently




                                                      • for many folks this is a totally obvious idea


                                                      • but for other folks it is freaky crazy stuff.



                                                      After all, setting aside just programming per se, back in the 90s one of the keys to the staggering success of General Electric at the time was Jack Welch's scheme where each manager simply fired the bottom 10% of people each year! (His book is terrific BTW.)



                                                      And I cringe to type the phrase "the gig economy" but in "the gig economy" we are all on "a trial basis" - from day to day and forever.



                                                      Winnowing programmers is incredibly, notoriously, difficult.






                                                      share|improve this answer



















                                                      • 13




                                                        Hopefully you mean as an off-hours contract project. Or as a final check after a meaningful selection process. Otherwise routinely making your selection only after bringing people onboard as employees is terrible for all concerned - it's expensive of both money and on-boarding effort, and it means often asking people to leave an existing job for a very uncertain alternative.
                                                        – Chris Stratton
                                                        19 hours ago






                                                      • 15




                                                        This may require that the candidate quit his or her current job to try out yours. This may not be bad if you want to hire from the unemployed only, but you're leaving some very promising people wondering "Why should I (quit my job/spend a full week of time off) just to interview?".
                                                        – David Thornley
                                                        17 hours ago






                                                      • 8




                                                        Do you tell your candidates what the process is up front? I would never accept a job offer that said "We don't want to rigorously interview you, we'll just let you work for us for a couple of weeks, and if you're not exactly what we're looking for, you're out the door". That is a huge risk to ask an employee to take, particularly if they have to quit their existing job first.
                                                        – asgallant
                                                        16 hours ago






                                                      • 6




                                                        In a lot of places this idea would be a breach of contract / employment law.
                                                        – Neuromancer
                                                        15 hours ago






                                                      • 4




                                                        What an awful idea.
                                                        – Lightness Races in Orbit
                                                        13 hours ago














                                                      1












                                                      1








                                                      1






                                                      Welcome new user, I've come to believe that the only way to find software engineers is, once you've found someone who seems to know what they're talking about,




                                                      • Simply pay them for a one or two week freelance contract. Actually have them jump in and do a real project on your real product with the real team.


                                                      This is becoming more and more common.



                                                      I think that's it.



                                                      It's the only way to know.



                                                      Everything else is useless, as the OP points out.



                                                      The amount of time/money you'll spend on the sundry alternatives ... might as well just put them on the project for a week.



                                                      (Depending on your style and project, you might retain 'em for a time period (a week) or some "task" for $x. Either way.)



                                                      If you consistently take this approach, you'll find after a year or two that, the money you wasted doing this approach, was indeed far less than the sundry other costs of search and hiring.





                                                      Some further thoughts, the tenor of this QA is



                                                      • For software engineers, recruitment processes fail - indeed they're often "hopeless". (One apex of this, and the particular one raised in frustration by the OP, is that hopeful programmers now just "game" the "technical questions" phase of things.)



                                                      • Note that even "google-style" absurdly detailed/extended recruitment processes ............ often completely fail. Programmers (in particular) often "just don't work out" no matter how careful the recruitment processes.



                                                      • By all means in any industry or mode of occupation, folks sometimes "don't work out" even after careful recruitment. However, this is especially a problem for software engineers - it is notorious.



                                                      {You may ask - why? How come it's particularly a problem with programmers? I know precisely why this is, and some people have their own theories on it, but no need to start another argument!}





                                                      Even more thoughts!



                                                      This answer has a big pile of downvotes and a big pile of upvotes.



                                                      Apparently




                                                      • for many folks this is a totally obvious idea


                                                      • but for other folks it is freaky crazy stuff.



                                                      After all, setting aside just programming per se, back in the 90s one of the keys to the staggering success of General Electric at the time was Jack Welch's scheme where each manager simply fired the bottom 10% of people each year! (His book is terrific BTW.)



                                                      And I cringe to type the phrase "the gig economy" but in "the gig economy" we are all on "a trial basis" - from day to day and forever.



                                                      Winnowing programmers is incredibly, notoriously, difficult.






                                                      share|improve this answer














                                                      Welcome new user, I've come to believe that the only way to find software engineers is, once you've found someone who seems to know what they're talking about,




                                                      • Simply pay them for a one or two week freelance contract. Actually have them jump in and do a real project on your real product with the real team.


                                                      This is becoming more and more common.



                                                      I think that's it.



                                                      It's the only way to know.



                                                      Everything else is useless, as the OP points out.



                                                      The amount of time/money you'll spend on the sundry alternatives ... might as well just put them on the project for a week.



                                                      (Depending on your style and project, you might retain 'em for a time period (a week) or some "task" for $x. Either way.)



                                                      If you consistently take this approach, you'll find after a year or two that, the money you wasted doing this approach, was indeed far less than the sundry other costs of search and hiring.





                                                      Some further thoughts, the tenor of this QA is



                                                      • For software engineers, recruitment processes fail - indeed they're often "hopeless". (One apex of this, and the particular one raised in frustration by the OP, is that hopeful programmers now just "game" the "technical questions" phase of things.)



                                                      • Note that even "google-style" absurdly detailed/extended recruitment processes ............ often completely fail. Programmers (in particular) often "just don't work out" no matter how careful the recruitment processes.



                                                      • By all means in any industry or mode of occupation, folks sometimes "don't work out" even after careful recruitment. However, this is especially a problem for software engineers - it is notorious.



                                                      {You may ask - why? How come it's particularly a problem with programmers? I know precisely why this is, and some people have their own theories on it, but no need to start another argument!}





                                                      Even more thoughts!



                                                      This answer has a big pile of downvotes and a big pile of upvotes.



                                                      Apparently




                                                      • for many folks this is a totally obvious idea


                                                      • but for other folks it is freaky crazy stuff.



                                                      After all, setting aside just programming per se, back in the 90s one of the keys to the staggering success of General Electric at the time was Jack Welch's scheme where each manager simply fired the bottom 10% of people each year! (His book is terrific BTW.)



                                                      And I cringe to type the phrase "the gig economy" but in "the gig economy" we are all on "a trial basis" - from day to day and forever.



                                                      Winnowing programmers is incredibly, notoriously, difficult.







                                                      share|improve this answer














                                                      share|improve this answer



                                                      share|improve this answer








                                                      edited 2 hours ago

























                                                      answered 20 hours ago









                                                      Fattie

                                                      6,99531324




                                                      6,99531324








                                                      • 13




                                                        Hopefully you mean as an off-hours contract project. Or as a final check after a meaningful selection process. Otherwise routinely making your selection only after bringing people onboard as employees is terrible for all concerned - it's expensive of both money and on-boarding effort, and it means often asking people to leave an existing job for a very uncertain alternative.
                                                        – Chris Stratton
                                                        19 hours ago






                                                      • 15




                                                        This may require that the candidate quit his or her current job to try out yours. This may not be bad if you want to hire from the unemployed only, but you're leaving some very promising people wondering "Why should I (quit my job/spend a full week of time off) just to interview?".
                                                        – David Thornley
                                                        17 hours ago






                                                      • 8




                                                        Do you tell your candidates what the process is up front? I would never accept a job offer that said "We don't want to rigorously interview you, we'll just let you work for us for a couple of weeks, and if you're not exactly what we're looking for, you're out the door". That is a huge risk to ask an employee to take, particularly if they have to quit their existing job first.
                                                        – asgallant
                                                        16 hours ago






                                                      • 6




                                                        In a lot of places this idea would be a breach of contract / employment law.
                                                        – Neuromancer
                                                        15 hours ago






                                                      • 4




                                                        What an awful idea.
                                                        – Lightness Races in Orbit
                                                        13 hours ago














                                                      • 13




                                                        Hopefully you mean as an off-hours contract project. Or as a final check after a meaningful selection process. Otherwise routinely making your selection only after bringing people onboard as employees is terrible for all concerned - it's expensive of both money and on-boarding effort, and it means often asking people to leave an existing job for a very uncertain alternative.
                                                        – Chris Stratton
                                                        19 hours ago






                                                      • 15




                                                        This may require that the candidate quit his or her current job to try out yours. This may not be bad if you want to hire from the unemployed only, but you're leaving some very promising people wondering "Why should I (quit my job/spend a full week of time off) just to interview?".
                                                        – David Thornley
                                                        17 hours ago






                                                      • 8




                                                        Do you tell your candidates what the process is up front? I would never accept a job offer that said "We don't want to rigorously interview you, we'll just let you work for us for a couple of weeks, and if you're not exactly what we're looking for, you're out the door". That is a huge risk to ask an employee to take, particularly if they have to quit their existing job first.
                                                        – asgallant
                                                        16 hours ago






                                                      • 6




                                                        In a lot of places this idea would be a breach of contract / employment law.
                                                        – Neuromancer
                                                        15 hours ago






                                                      • 4




                                                        What an awful idea.
                                                        – Lightness Races in Orbit
                                                        13 hours ago








                                                      13




                                                      13




                                                      Hopefully you mean as an off-hours contract project. Or as a final check after a meaningful selection process. Otherwise routinely making your selection only after bringing people onboard as employees is terrible for all concerned - it's expensive of both money and on-boarding effort, and it means often asking people to leave an existing job for a very uncertain alternative.
                                                      – Chris Stratton
                                                      19 hours ago




                                                      Hopefully you mean as an off-hours contract project. Or as a final check after a meaningful selection process. Otherwise routinely making your selection only after bringing people onboard as employees is terrible for all concerned - it's expensive of both money and on-boarding effort, and it means often asking people to leave an existing job for a very uncertain alternative.
                                                      – Chris Stratton
                                                      19 hours ago




                                                      15




                                                      15




                                                      This may require that the candidate quit his or her current job to try out yours. This may not be bad if you want to hire from the unemployed only, but you're leaving some very promising people wondering "Why should I (quit my job/spend a full week of time off) just to interview?".
                                                      – David Thornley
                                                      17 hours ago




                                                      This may require that the candidate quit his or her current job to try out yours. This may not be bad if you want to hire from the unemployed only, but you're leaving some very promising people wondering "Why should I (quit my job/spend a full week of time off) just to interview?".
                                                      – David Thornley
                                                      17 hours ago




                                                      8




                                                      8




                                                      Do you tell your candidates what the process is up front? I would never accept a job offer that said "We don't want to rigorously interview you, we'll just let you work for us for a couple of weeks, and if you're not exactly what we're looking for, you're out the door". That is a huge risk to ask an employee to take, particularly if they have to quit their existing job first.
                                                      – asgallant
                                                      16 hours ago




                                                      Do you tell your candidates what the process is up front? I would never accept a job offer that said "We don't want to rigorously interview you, we'll just let you work for us for a couple of weeks, and if you're not exactly what we're looking for, you're out the door". That is a huge risk to ask an employee to take, particularly if they have to quit their existing job first.
                                                      – asgallant
                                                      16 hours ago




                                                      6




                                                      6




                                                      In a lot of places this idea would be a breach of contract / employment law.
                                                      – Neuromancer
                                                      15 hours ago




                                                      In a lot of places this idea would be a breach of contract / employment law.
                                                      – Neuromancer
                                                      15 hours ago




                                                      4




                                                      4




                                                      What an awful idea.
                                                      – Lightness Races in Orbit
                                                      13 hours ago




                                                      What an awful idea.
                                                      – Lightness Races in Orbit
                                                      13 hours ago











                                                      0














                                                      I don't think you need to change the questions, just how and what you ask.




                                                      It's gotten to the point where you pretty much can't ask a question without the applicant already having pre-studied at least a version of that same task and hence knows, roughly, what the solution is.




                                                      This isn't a zero sum thing, you can feed off the solution for an entire interview on it's own if you want, and get a deep understanding of the interviewee's skills (assuming as the interviewer you have your own technical skills).



                                                      You present the question, the interviewee creates a solution (maybe code, maybe whiteboard). This is the start:




                                                      • Tell me how this works

                                                      • What factors led you to choose this solution?

                                                      • Are there any other ways of doing this?

                                                      • Why is your solution better than the others?

                                                      • Are there any potential advantages in the other solutions missing from your solution? what scenarios might that apply?

                                                      • Having just written this off the cuff, any refactorings you'd like to do now you've looked it over?

                                                      • If you didn't do this test driven, what tests would you be looking to write/do to ensure this is correct?

                                                      • Any bugs you've noticed?

                                                      • Do you think the code is production quality? Could another developer support/refactor it without knowledge transfer from you? What would you need to change to ensure it's intent is understood?


                                                      Someone who has memorized an algorithm or pattern without understanding it will not be able to drill down into detail, but a good developer should be able to have discussions on these topics, even if their raw solution wasn't perfect (and seeing someone discover a better solution while talking to you and be prepared to call it out shows a maturity over code/design reviews and refactoring which are highly desirable).






                                                      share|improve this answer




























                                                        0














                                                        I don't think you need to change the questions, just how and what you ask.




                                                        It's gotten to the point where you pretty much can't ask a question without the applicant already having pre-studied at least a version of that same task and hence knows, roughly, what the solution is.




                                                        This isn't a zero sum thing, you can feed off the solution for an entire interview on it's own if you want, and get a deep understanding of the interviewee's skills (assuming as the interviewer you have your own technical skills).



                                                        You present the question, the interviewee creates a solution (maybe code, maybe whiteboard). This is the start:




                                                        • Tell me how this works

                                                        • What factors led you to choose this solution?

                                                        • Are there any other ways of doing this?

                                                        • Why is your solution better than the others?

                                                        • Are there any potential advantages in the other solutions missing from your solution? what scenarios might that apply?

                                                        • Having just written this off the cuff, any refactorings you'd like to do now you've looked it over?

                                                        • If you didn't do this test driven, what tests would you be looking to write/do to ensure this is correct?

                                                        • Any bugs you've noticed?

                                                        • Do you think the code is production quality? Could another developer support/refactor it without knowledge transfer from you? What would you need to change to ensure it's intent is understood?


                                                        Someone who has memorized an algorithm or pattern without understanding it will not be able to drill down into detail, but a good developer should be able to have discussions on these topics, even if their raw solution wasn't perfect (and seeing someone discover a better solution while talking to you and be prepared to call it out shows a maturity over code/design reviews and refactoring which are highly desirable).






                                                        share|improve this answer


























                                                          0












                                                          0








                                                          0






                                                          I don't think you need to change the questions, just how and what you ask.




                                                          It's gotten to the point where you pretty much can't ask a question without the applicant already having pre-studied at least a version of that same task and hence knows, roughly, what the solution is.




                                                          This isn't a zero sum thing, you can feed off the solution for an entire interview on it's own if you want, and get a deep understanding of the interviewee's skills (assuming as the interviewer you have your own technical skills).



                                                          You present the question, the interviewee creates a solution (maybe code, maybe whiteboard). This is the start:




                                                          • Tell me how this works

                                                          • What factors led you to choose this solution?

                                                          • Are there any other ways of doing this?

                                                          • Why is your solution better than the others?

                                                          • Are there any potential advantages in the other solutions missing from your solution? what scenarios might that apply?

                                                          • Having just written this off the cuff, any refactorings you'd like to do now you've looked it over?

                                                          • If you didn't do this test driven, what tests would you be looking to write/do to ensure this is correct?

                                                          • Any bugs you've noticed?

                                                          • Do you think the code is production quality? Could another developer support/refactor it without knowledge transfer from you? What would you need to change to ensure it's intent is understood?


                                                          Someone who has memorized an algorithm or pattern without understanding it will not be able to drill down into detail, but a good developer should be able to have discussions on these topics, even if their raw solution wasn't perfect (and seeing someone discover a better solution while talking to you and be prepared to call it out shows a maturity over code/design reviews and refactoring which are highly desirable).






                                                          share|improve this answer














                                                          I don't think you need to change the questions, just how and what you ask.




                                                          It's gotten to the point where you pretty much can't ask a question without the applicant already having pre-studied at least a version of that same task and hence knows, roughly, what the solution is.




                                                          This isn't a zero sum thing, you can feed off the solution for an entire interview on it's own if you want, and get a deep understanding of the interviewee's skills (assuming as the interviewer you have your own technical skills).



                                                          You present the question, the interviewee creates a solution (maybe code, maybe whiteboard). This is the start:




                                                          • Tell me how this works

                                                          • What factors led you to choose this solution?

                                                          • Are there any other ways of doing this?

                                                          • Why is your solution better than the others?

                                                          • Are there any potential advantages in the other solutions missing from your solution? what scenarios might that apply?

                                                          • Having just written this off the cuff, any refactorings you'd like to do now you've looked it over?

                                                          • If you didn't do this test driven, what tests would you be looking to write/do to ensure this is correct?

                                                          • Any bugs you've noticed?

                                                          • Do you think the code is production quality? Could another developer support/refactor it without knowledge transfer from you? What would you need to change to ensure it's intent is understood?


                                                          Someone who has memorized an algorithm or pattern without understanding it will not be able to drill down into detail, but a good developer should be able to have discussions on these topics, even if their raw solution wasn't perfect (and seeing someone discover a better solution while talking to you and be prepared to call it out shows a maturity over code/design reviews and refactoring which are highly desirable).







                                                          share|improve this answer














                                                          share|improve this answer



                                                          share|improve this answer








                                                          edited 57 mins ago

























                                                          answered 1 hour ago









                                                          The Wandering Dev Manager

                                                          30.9k1060110




                                                          30.9k1060110

















                                                              protected by Jane S 9 hours ago



                                                              Thank you for your interest in this question.
                                                              Because it has attracted low-quality or spam answers that had to be removed, posting an answer now requires 10 reputation on this site (the association bonus does not count).



                                                              Would you like to answer one of these unanswered questions instead?



                                                              Popular posts from this blog

                                                              Morgemoulin

                                                              Scott Moir

                                                              Souastre