We Need to Stop Using Leetcode
If you’ve worked as an engineer or in a complex, intellectual profession, you’ve almost certainly come across modern ideas of intelligence. I know I have. I’ve taken IQ tests, been asked for my high school transcripts, and been asked mathematical riddles, no I’m not joking, riddles, in interviews.
Underneath all of this was one commonality: someone thought they were so smart that their idea of smart was the definition of smart, and they knew how to measure it.
It’s made me reflect on how I define intelligence. I’ve come to believe, over time, that it’s not what some in the technology industry would have you believe. The easy, obvious ideas about what intelligence means miss a few things:
Human character (humility, honesty, fairness) is inextricably linked to our ability think with clarity.
Life is so complicated and the amount of knowledge available to us is so vast that even after many hours of study and practice all we really get is a sense of how some things work and a good grasp of a few fundamental concepts.
The trouble with identifying intelligence is that it requires a definition of intelligence. You have to cast people as objects with possessive capabilities (in an intellectual sense), define intelligence and measure it. There is a chicken and egg problem here, in that you assume that, using the tool which is your brain you should be able to deduce how your brain works and reduce it into a definable, measurable test that can be applied consistently across all brains.
There are some majorly challenging issues with this idea:
An answer to that question of how to define intelligence assumes the definition won’t change, meaning whoever answers the question would have to know everything there is to know about human intelligence when they answer it.
You would, in effect, be defining intelligence using the tool that possesses intelligence (the human brain). Is a tool with the type of intelligence it seeks to define also capable of defining its own intelligence using that intelligence? Can we both know and use our intelligence?
Following from 1 and 2 above, given the breadth, depth and nuance of the field of epistemology, and the obvious lack of consistent and unilaterally acceptable answers we have to the fundamental questions in that field, how could we just gloss over centuries of philosophical inquiry with a single definition?
I’ve never heard satisfying answers to the above questions. They usually don’t get addressed directly or consistently. Nonetheless, in many places in the software engineering industry you will find people who have built processes on the idea that they can define and measure a specific type of intelligence.
The idea is they can measure your mathematical intelligence. I mean to show here that this is wrong and harmful. I mean to use this as a specific example of the general idea that attempts to define intelligence (even constrained, specific types of intelligence relative to a domain), are self-defeating in nature and result in practices which delimit and pre-empt the development of creative, novel ideas in a field.
I do argue below that it is possible to assess someone’s grasp of specific concepts (say, for computer science: computer architecture, operating systems, data structures, algorithms, etc.), just not their intellectual capacity to apply those concepts. I also argue that when you define a form of intelligence, and you tie people’s lives to that idea, people naturally start to focus on gaming that measurement. And that has happened. And that is bad.
The Troll Toll
Believe it or not, many companies take the stance that degrees, even advanced degrees, do not prove you know enough to do the job of software engineering. People could shell out tens of thousands of dollars and study in their nights and evenings while working full time for a Bachelor of Science in Computer Science, and still, you’re not good enough. Community contributions (blogs, research papers, conference talks), personal projects, experience and open-source contributions are not enough.
The implicit assumption in the interview practices common in some companies is that they don’t need to bother assessing you as a whole person. They don’t need to know your background, how hard you studied, what contributions you’ve made to the field or your own personal interests. They can just define intelligence and just use their own idea of what intelligence means to figure out if you’re worth it. Your past, critical thinking capacity, and personal interests take the back seat to their ideas of what intelligence is.
What takes the place of the “whole person” concept is Leetcode (and Leetcode style “system design” problems). The questions take concepts in computer science (data structures and algorithms) and software engineering (system design) and form them into a contrived scenario using the concepts as building blocks for a tricky, non-obvious, riddle style problem.
They all follow a similar formula and are never actually based in an understanding of the concepts but rather in a non-obvious and tricky problem formulation that is hidden amongst the subject matter of computer science and software engineering. Remember, they’re measuring your general intellectual capacity to apply computer science concepts, not your understanding of the concepts. They want to know if you can solve a Sudoku puzzle style problem that proves you’re generally intelligent; not how much you know about mathematics or computer science.
They usually try to mirror realistic scenarios, although, if you’ve been an engineer long enough, you know how few are the times that problems arise that are Leetcode-y in nature in reality. In any case, the general idea is to create a scenario in which they can measure your capacity to apply the concepts of computer science, not your understanding of the concepts. To do that they have to create the scenario. To do that they have to define mathematical intelligence.
And so we take one step away from reality and into a specific definition of intelligence that people are to be measured by. And one step away we have taken; entire books and websites have sprung up which are dedicated to helping people develop the skill of gaming assessments which attempt to measure this definition of your capacity to apply computer science concepts.
Yes, the skill of gaming the measurement; interviewing. Not, engineering, or system design, or mathematical exploration and discovery, interviewing.
For instance:
NeetCode
A better way to prepare for coding interviews.neetcode.io
Let’s consider the obvious, commonsense problem with this fact. Obviously, these books don’t teach you the same thing as books about the design and analysis of algorithms or the principles of software architecture. That wouldn’t make sense since then the books would just be about the actual subject matter, not the interview questions, right?
What’s more, these interview questions are designed to fail candidates. They are specifically intended to be arbitrarily challenging. They are meant to use their definition of intelligence as aggressively as possible and find people who perform best in that sandbox. The irony is using these types of problems in interview processes ends up selecting against people who enjoy critical thinking and bold exploration of new ideas. Instead, you select for people willing to succumb to cultural limitations for short term gain.
The problems just are not what the job of software engineering is about. They almost always require a non-obvious insight specific to the problem formulation, not the subject matter related to the problem. It is a lot like coming up with a riddle in a foreign language and asking someone to solve the riddle to prove to you they know the language. You could immerse yourself in a foreign culture, learn the nuances of the language in an idiomatic sense, read the classical literature written in the language and be great at it; and still not know how to solve a riddle.
Intelligence, Evaporated
Leetcode problems are not interesting. Yes, they can be good to use as regular practice or in conjunction with studying data structures and algorithms, but they’re toy problems. They’re for fun and to get yourself thinking about what you’re studying. They are not even loosely correlated to the skill of mathematics or software engineering.
The great computer scientists before us have proven what’s possible with computer science and mathematics. Ideas like Church’s lambda calculus and Turing’s a-machines, for instance. Or systems like massive, powerful operating systems that are used around the world and digital networks that span the globe and connect people to each other where it was never before possible.
These things require serious critical thinking and imagination to make possible. What’s more, if you can peer past the obvious narrative of a small number of great people doing all the work behind major human accomplishments, you’ll find that achieving major intellectual milestones requires a lot of teamwork and collaboration. It requires a healthy dose of humanity: humility, empathy and curiosity.
Reducing intellectual capacity, even domain specific intellectual capacity, to a single, measurable set of playground style tests ends the march forward in a domain. It eschews the three problems I outlined in the introduction by supposing
What intelligence looks like is understood, so it will never change. The process will never improve. No new insights into what it means to be intelligent will come forth. Generations will not innovate in their ability to apply concepts.
The tool that possesses intelligence defines it. There was no need for any greater forces in the universe to create our intelligence, we can do it ourselves! We are gods!
Epistemology books can be tossed away. We’re good now. We know we know what it means to know, we have the answers we needed.
It also forces the unimaginably vast and varied tapestry of human intellect into a single mold of a few people’s creation. There is not room or space for changing the definition of how concepts are applied, meaning we have crystallized the field using the set of concepts that are now known.
When new concepts arise the intellectual tools of a field change fundamentally. Calculus is, in very many ways, totally new and different than algebra. The types of mental exercises you need to do a derivative differ from that of solving an algebraic equation. The definition of domain specific intelligence does change when new ideas are introduced. And that’s a remarkable fact.
And to find those new ideas you have to have people who are bold enough to be critical of the existing ideas and find their own way outside them to bring back something new. In that space, against the blank backdrop of the unknown, human character becomes very important. There we realize how little we know, how important humility and collaboration is, and how daring and courageous we have to be to find new ideas.
Supposing one measurement of intelligence should rule them all ends that process. It starts people off on a path to obsession and mastery of a single set of limited ideas defined by a few people. It splits people by who likes that measurement and who doesn’t. It divides people into who’s smart and who isn’t. It lies, cheats, and steals to perpetuate a self-defeating, unintelligent idea.
It is, in many ways, subversive to the human spirit to suppose you can define intelligence and split people based on your idea of intelligence. It also emphasizes silly, arbitrary and general ideas over domain specific grasp of specific, fundamental concepts. The former being fodder for the type of dilettante the 21st century technology industry has come to venerate, the latter being the subject of intrigue to people who are curious.
Intelligence, Defined (or not)
The smartest thing I think I’ve ever thought is that I’m not really that smart. I’ve spent nights and weekends, years on end, studying and racking my brain to discover how great intellectual achievements in computer science have occurred. After all that time, and many lessons on the way, it’s abundantly clear to me that no one is going to get far alone and it takes a lifetime to truly learn a skill that is associated with a complex domain (like engineering, law, medicine, etc.).
No one has the key to all the kingdoms. No one rules over all knowledge. It is no person or groups of persons right to use their own personal definition of what they believe intelligence to be to delimit the potential of others, cast judgement as to what others potential is, or filter others out of places where they want to be.
If we want to find great intellectual achievements, we ought to learn to develop the human characteristics required for any great feat (humility, team work, empathy), ground ourselves in a true understanding of a specific, real domain (computer science, law, medicine) and make real contributions to it, either in practice or academia.
Real contributions that are carefully cited and respectful of the ideas of others that we used along the way, lest we become blind to the fact that others have contributed substantially to our understanding and drunk on our own prowess.
When it comes to assessing someone for a job, for the most part, at the end of the day, all you can really do to assess another person is determine:
If they’re interested (do they have their own unique ideas about the field? have they done personal projects? have they done projects at work of their own volition?)
If they have done some work in laying their foundational knowledge (say, they understand Big-O notation and the time complexity of an element access in a hash table or some other aspect of fundamental data structure)
If they’ve put some thought, one way or another, into the more challenging, ambiguous aspects of the field (can they give a stance on the debate between waterfall and agile methodologies, do they understand how important clarifying requirements is, etc.)
Eschewing a balanced assessment of someone's grasp of specific, concrete concepts in their domain for a definition of their intellectual capacity to apply those concepts is a fools errand. It is an artifact of hubris and a departure from the conditions that create great intellectual achievements.
If we want to benefit from the awesome potential of our intelligence we ought to learn how to foster the conditions that nurture it, not take to bickering and arguing amongst one another about how we measure up against a single definition of it, and how much cash we can leverage out of the people around us using that definition.
I’ve never met someone who seems to have a good grip on themselves and who takes hard, specific stances on ambiguous questions like what defines intelligence. Usually, I see people do that when they have something to gain. Of course, I do see people who seem to have their wits about themselves who have strong conviction in a few simple, obvious principles like humility and empathy.
If we want greatness, the way there is to be kind to one another, critical of our assumptions and open to new ideas. If we want greatness we have to learn to build one another up, encourage one another to be authentic, and remain open to the ambiguous and complex fields that we work within.
We have to be real with one another. We need to stop using Leetcode.