What does it take to be a Software Engineer? (*for non CS folks*)
I completed a program in Computer Science and Public Policy from the University of Chicago and now work at a mid-sized fintech as a Software Engineer. How and why that came to be is a story for another day. What did it take though to get here? Software engineering is usually the natural culmination for many who study Computer Science. But what about folks like me who had no formal CS background and whose work experience in disparate sectors like policy and non-profits remain irrelevant to tech?
I hope to encourage some folks who might be on the fence about working in tech to cross over to my side. I’ll elaborate on my experiences in the tech world some other time. This write-up is more for those who think they do not qualify for engineering roles or who think that they won’t make it through the interviews or won’t succeed at the job if they eventually do. In my conversations with folks in MSCAPP as well as other non-CS programs, there are a surprisingly large number of people who never consider the engineering path for the above-mentioned reasons. This is not only a disservice to the talented folks in non-CS programs but also a massive loss for the tech industry that is starved of diversity in education, ideologies and experiences.
What do you need to learn in school?
The essence of computer science as I understood it is distilled down to abstractions and how to build progressively larger and more complex units of work composed of smaller abstractions. Algorithms and Data Structures and programming experience is the bare minimum you need to make it through the interviews. Curiosity, the ability to learn, and peeling back the layers to dig deeper ensures a more enduring success in the field. You really don’t need a lot more to get started. It’s been almost 9 months for me as an SDE and the college courses I took that I find useful at my job are: Algorithms and DS, OOP, Cloud Computing (AWS is inescapable), Applied Software Engineering and Python Programming (for the practice). The first three were essential and the other two are just nice to have. Three courses out of the 18 I took in college were coming in handy at work! The rest was mostly self-taught both before school and during the job.
Can you thrive in tech without a CS background? Yes, most definitely. Depending on your predisposition, you may even do it better without a college education. The first wave of tech companies were helmed by people who preceded the whole notion of Computer Science as an education option. They came from a wide variety of fields – other engineering disciplines, mathematics, social sciences – and were united by a love for technology and a fascination for building something fun.
Hopefully we’ve established that it is not necessary to have a CS education to break into tech. This is not to say that a full-fledged computer science education is worthless. It’s hard to compete with someone with solid conventional credentials who passionately pursued CS in school for four years with internships and projects to show for it. However, I urge you not to underestimate grit and curiosity here. Life is long and you’ll make up for lost time. If you find engineering fun, stay at it and time will do the rest, regardless of what your education or previous work choices have been.
What does it take to get interviews?
Some luck for sure. I can’t discount some good fortune that came my way. I did try my utter best to place myself in situations where I’d see more of them. Applying relentlessly across engineering roles regardless of interest, location, or industry helped me build some confidence in my interviewing and familiarized me with the whole process. This was important so that by the time I interviewed for my current role, I was a bit more confident, with calmer nerves and more practice.
If you haven’t studied CS, you are going to have to work harder to stand out. Working on independent projects and showcasing them as much as you can everywhere is vital. This is a slow process, but please start no matter how late it is. It is a lot of fun and there are plenty of easy, quick projects you can work on to build a taste for such work.
Talk to people a lot! Tech hiring, regardless of what people say, is still quite a social and networked affair. Referrals are helpful. People are more than willing to help if you ask. In my limited sample size, 3 out of 10 people did. Getting interviews is definitely what I found to be the toughest link of the chain. It wasn’t learning computer science and engineering or performing well at the job once I was in; it was somehow convincing folks to take a chance with me.
What it takes to get through the interviews?
Software engineering interviews are mostly about algorithms and, consequently, about Leetcode. This is unfortunately the industry standard. It is not a reflection of what the job will be like, but somehow the trillion-dollar industry hasn’t been able to come up with a better way to quickly and cheaply test candidates’ CS knowledge. So the only recourse here is to start Leetcode a few months before. I did about 120 Leetcode problems over time, mostly Medium, but many Easy and a few Hard too. Whiteboard with friends if you have that luxury. Practice interviewing and you’ll eventually get better at it. Almost everyone does with time.
Other normal interviewing advice applies too. Be someone people want to work with. Interviewers are, of course, wondering if this is someone they’d want on their team. Don’t be an asshole or arrogant about your skills or grossly underconfident about everything you do. Communicate well. These are my opinions on what I saw worked.
What to do once you get the job?
Take some rest. You are most likely going to begin a journey of self-doubt, of perpetual impostor syndrome with periods of excitement and euphoria combined with fear and trepidation. It is a difficult field, but the people I have seen succeed in tech are those who maintain a constant state of curiosity and wonder about new tools and technologies and who are constantly trying to learn.
I worked 60–70 hour weeks the first few months at my job, not because I was asked to, but only because I wanted to learn everything there was to get started. I may not have been as prepared as some CS grads, but I did my best to make up for it in time, interest, and effort put into learning whatever I needed—be it Java, Kotlin, Spring, or databases—to start contributing to the team. The most important lesson I’d learnt was to not try to study from the bottom up by going through tutorials and courses on every topic necessary. Instead, pick up some small work and then learn whatever is necessary to complete that task. Then pick another task and repeat the cycle. One day you’ll wake up and the task you picked up will no longer cause fear and anxiety. Even this will pass.
The advice I had for myself throughout was to keep laughing despite the fear and anxiety that unknown and difficult tasks may cause you. The tech world, to me, has always been amusing so laughing at both the world and myself was always easy. Everything else will fall into place as long as you don’t let the fear cripple you, and you maintain your sense of wonder, curiosity, and interest. Just remember why you chose engineering in the first place. And if I didn’t mention it before, you’ll probably be grossly overpaid—so that’s definitely a big motivator too.
Takeaway
There’s a lot to complain about tech (and I will in a separate post) but it is significantly more open to outsiders, in my opinion, than other fields such as policy, economics, law, etc. There is relatively little gatekeeping here and more willingness to give chances to those without formal CS training. If you are interested in technology, computers, and building something, tech is a great place to be. As long as you are passionate, show it through independent work and projects, and keep learning, you have a very high chance of carving a meaningful space for yourself in the industry (not necessarily big tech).
Addendum
I’m writing this from the comfort of my newfound role in the field I am passionate about. Human biases may have painted my journey differently now than what I felt while living through them. Receiving interview calls was difficult and this was a particularly stressful time in my life. As with everything else in life, some good fortune, a few privileges, and a conducive social and personal life were essential.
I must also note that none of these modest goals would’ve been achieved without my closest and childhood friend Aditya constantly encouraging and motivating me. Of all of life’s treasures, old friends are truly one of the most precious. His advice and steadfast support in my abilities, when I myself had none, is what I have tried to communicate through this article.