disclaimer: this guide is mainly intended for those aiming to get a computer science internship. i don’t know anything outside these areas, but some of the ideas presented here may still be relevant. i am also learning, so let me know if you find something incorrect.
intro
spring 2023 (january–april) term has just concluded and i want to share what has worked well for my seeking process. this is also intended as a guide for those who want to find their first job. here, i will use the terms “internship” and “co-op” interchangeably just because the word “internship” seems to be known by more people. at least here, co-op is usually part of the degree program registered in a school.
in general, getting your first internship is simple but challenging. it requires two steps:
-
getting the interview
-
passing the interview, a.k.a. getting the offer
getting the interview
to get the interview, you need to get noticed by employers and called for an interview. i would argue that this is harder for a first internship as most of us don’t have anything good to show yet. this can be improved if you are a student and utilise all the resources given by the university.
here are some core components that i think will help you get the interviews ordered by significance:
good resume format
first, the resume needs to be relevant, concise, and in .pdf format.
also, the resume needs to be able to be parsed by resume parser. passing the resume parser is important here, as some companies might filter their candidates using this automated parser first before passing it to a person.
in order for your resume to be effectively parsed, you need to have a resume with one column. i’m not sure if you can make it work with two columns, as i have not tried, but better be safe in here. one page is also recommended, as recruiters do not want to spend a lot of time looking at your experiences. more of the explanations are here: https://www.careercup.com/resume.
finally, if you are looking for a recommendation, i use this famous jake’s resume. it uses latex. overleaf has an online latex editor that makes it easy to edit it. make sure to download it as a pdf.
next, for the contents: always do a grammar check and write all the bullet points in a concise way while also showing your accomplishments. i used the star method to be able to easily outline what i have done concisely. if you are kind of bad at english and finding the perfect words like me, you might want to use chatgpt. you can ask them, “reword these bullet points in a resume in a star format,” and show your current bullet points.
work experience
ah, the loop that you can never break.
why do i need to make this point if the post is about someone getting their first co-op? surely none would have any relevant work experience, right? you are half-correct. most people would never have any relevant, in this case, developer job. but you can always try to get one or even others that have no direct relevance.
first, if you are a student, getting a tutoring job can be beneficial, as it will show that you can communicate your thoughts clearly to teach people. in fact, many universities always need peer tutors or teaching assistants. i applied for a teaching assistant job back when i was at langara, and i am forever grateful for that decision. i was really pessimistic, as i have tried applying for many opportunities in the past but never got in. taking that first step in applying is crucial.
the key point here is to try to have some experience (not mandatory of course). i would argue that even if the job is not tech-related, it can still be useful as soft skills are arguably more important when you are starting. just make sure to keep school courses as the priority.
technical projects
projects are a huge part of what makes applying to cs jobs different from other professions. the fact that we need to build something in our free time to get those jobs can be daunting. for me, though, i think this is a good benefit to have. as we are more likely to be assessed by our projects, which we can continuously develop over time, and not our grades, which can only be evaluated mostly on the 2-hour exams.
to have good projects, you need to find problems that you think you’d enjoy solving. alternatively, you can also choose a domain in computer science in which you want to specialise. here are some domains that i see as having some prospects (at least on the job board):
- web development
if you think you enjoy this, i recommend starting to learn from freecodecamp and starting to build projects from there. there are also many projects on youtube that you can learn from. - ai/ ml
arguably the most exciting part of cs, i don’t specialise in this. but i have heard that andrew ng’s machine learning course to be a really good one. - game development
this can also be related to graphics. i also never had the chance to try this. i would try finding a unity 2d or 3d course on youtube or udemy to learn from. - embedded programming
this is probably the domain with the least competition but with good prospects too. taking an embedded programming course can be a good start. sfu has cmpt 433 if you are interested.
there might be more niche domains, but there are these four types of projects. if you are truly sure of what kind of internship role you want to get, i think having projects focused on one domain will be really helpful in making you stand out as a candidate.
what has worked for me to have these projects is to focus on classes that give good projects first. this is what i did as i took cmpt 213 (object oriented design), which gives me a java swing and oop project; cmpt 272 (web development), which gives me an angular project; and cmpt 276 (software engineering), which gives me a full-stack web development group project.
you can also do projects at hackathons, which generally take the least amount of time. just make sure you have a good teammate and have a good plan for what you think you will be doing.
so if you are still finding for an internship, try to focus on classes that give good projects. i would leave the harder classes later as long as it’s not an important prerequisite for another class.
organization experience
for most people, doing things alone can be a bit stressful, so why not make it fun by doing it with others or for others?
i find the most rewards in building things for organizations, as i know the result is useful for others too. try finding tech-related organisations if you want to find more like-minded peers. alternatively, you can just try to be in any organisation you’d like to be in and offer to build something for them to make club life easier. the most common one is to build a website for that organisation.
i really enjoy being in an organization, as i think community plays a big part in who we are and the enjoyment that comes from there.
credits taken
a.k.a. expected graduation date. having an earlier graduation date helps, but make sure to be honest that this graduation date is possible. i usually set my graduation date to the earliest possible, though i may extend it if i think i will have more co-ops.
many companies are more likely to hire candidates near their graduation, as internships are basically a relatively reliable way for them to get good full-time candidates.
thus, having a delayed internship might not be a bad idea at all, as (1) it is usually easier to get one and (2) there are more chances for the company to offer you a full-time position.
therefore, if you can work in the non-summer term (studying at canada both for international and domestic), i personally think that it’s fine to delaying your co-op term for more important and classes with worthwhile projects. just make sure that your first co-op is the one you think you will learn a lot.
gpa
does gpa matter? hmm, i don’t know, and i think many people worry too much about this. some companies might think it matters; others might not think about it at all.
gpa might matter, but i think the roi is better if you leverage other things listed before rather than just focusing on school (ex. work, organization, projects, hackathons).
thus, what you can do is to just study consistently while also maintaining your other areas of life.
right now, school life is not really my highest priority. i just need to make sure that i finish all the assignments and quizzes on time and get the general gist of it. prioritising projects, organisations, work, or even making sure you are not burned out and enjoy life is definitely more important.
this is a big realisation for me now that i have transferred to the university. this might not be the case at all if you need to transfer or pursuing graduate school.
look at what kind of life you want to be living 5 or 10 years from now and reverse engineer it from there. from this perspective, i see grades as not really important. this is also coming from a person who had a quite challenging high school experience in indonesia. i realised how much time i spent studying, which made me ignore other areas of life. life is short, and i need to make sure that i get the most out of it.
extra tips
there are also many highly underrated tips that i know will help your applying journey
1. apply early
always apply early! if possible, on the first day the application is open. most companies interview their candidates on a rolling basis. it means they will not wait until the due date of the application to start interviewing. this means the earlier you are, the more chances you have, as the internship slot still remains open.
this means that sometimes late applicants, no matter how good they are, may never be looked at at all if the slot is already filled.
even if the application is not open yet, you can check the habits of when the company usually post by looking at the past year history. if you don’t know about this yet, i think contacting their recruiter is totally fine! it might also be a bonus point as it shows that you are truly interested in the company.
2. get referrals.
i have never really done this step, but i know some of my friends who have. having referrals truly helps in securing that first round of interviews. i thought that this was kind of unethical because someone with referrals may get interviews even though they are less qualified. but this is simply false; the employer who made that referral may be putting their credibility in jeopardy as they recommend this worker as good.
word of mouth, after all, plays a huge role in how we operate in society. we can easily trust another person if a trusted friend recommends them to us.
3. message recruiters on linkedin.
this strategy, even though it may feel unnatural for many peoplet, can be proven very effective. make sure that you reword your message to be professional and direct, and tone the word to never expect anything. it is also highly recommended that you show interest in that company by explaining what you have done that may be related to what they are currently doing.
in fact, this is what one of my friends did, and it actually landed them a job as a software engineer intern. you never know where it might take you.
4. expect failure and fear not trying.
what has worked for me to still keep applying every day is to always treat failure as the expected scenario. i think this is quite easy for people who are generally still finding their first co-op. after all, it stinks, but it’s really not the end of the world if we don’t get it, right? but now that we still have the chance, it’s best to always keep trying ᕙ(’▿‘)ᕗ.
one of the most important thing is to have a good mindset.
what if your goal is to try to get 50 rejections instead of focusing on getting an offer? i think you will be much more focused on applying many more things. of course, make sure that the application is filled well.
passing the interview
an interview can be very nerve-wracking, especially if you don’t have much experience with it.
personally, i don’t have much experience with this as i have only been in two technical interviews. i can only learn from this, especially from the one that got me an offer.
show interest
companies really like it if you are genuinely interested in their mission. you can show this by researching their product and what they have done. you can also share this research with them via a link (notion or google docs).
lastly, always ask questions in the end of interview. i find it better if we tailor this question to good question, which is something that is unique and you can only ask to this interviewer rather than general ones.
ex:
- i saw that you have worked as x and now worked as y, what has been the biggest change in your new role?
be yourself
be curious; answer questions like a short story, factual but also engaging, also don’t make it too long (2–3 sentences max). don’t be afraid to show struggles. i think people really admire authenticity, as honesty makes you relate more to them.
have a webcam that is centered on you, and try to look at the webcam while talking to the interviewer. this will make the other end feel more like in a natural conversation.
i have also heard that amazon’s leadership principles is really useful in general, especially if the interview is behavioural.
master algorithms and data structures
if doing projects is the grind for getting the interview, then mastering algorithms is the grind for passing the interview.
doing blind 75 i think that is more than enough to get the first co-op. in fact, i have only finished the first half of it. just make sure to always revise it and understand, not memorise, the solutions. this will allow you to solve problems you have not encountered before because you already understand the underlying data structures.
master related cs topics
in general, you might also need to know object-oriented programming and design.
knowing 4 oop principles, solid principles, and design patterns are very useful. this is what i was tested on in one of my technical interviews. i actually learned most of this from sfu’s object-oriented design course, cmpt 213.
you also need to check the job description. if it requires other knowledge like networking, functional programming, and other related stuff. you may need to prepare yourself for these things too.
have fun
the last but most important thing to have, i think, is to just enjoy it. even if you fail, you will still get something out of it. sometimes you pass it, and other times you learn from it.
there are no better ways to get better at an interview than to keep doing it and treating it as a ‘game’.
conclusion
this is all for now. i really hope this guide can be useful to you. getting an internship, especially the first one, can be really hard. these are just some of the suggestions that i know will be helpful.
i apologize if there is any mistake. i’m very far from many people in cs knowledge, but i enjoy writing and sharing about this stuff. i know that many advices are quite repetitive and already easily known in the internet, but i hope you find at least one thing useful from here :).