Friday, May 17, 2019
Careercup Top 150 Questions
Cracking the Technical oppugn by Gayle Laakmann, Carg iodinrCup. com 150 Technical interrogate Questions and Solutions, writ ecstasy by experts. PLUS Behind the scenes look at Google Microsoft, virago and Yahoo hearings. Interview war Stories the view from the new(prenominal) side. Advice on how to prelude 24 types of c wholly into question questions. Copyright Information Copyright 2009 by Gayle Laakmann All rights reserved exclusively for emailprotected google. com www. carg peerlessrcup. com Table of Contents Introduction Practice Interviews. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6 The Microsoft Interview. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 The Amazon Interview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 The Google Interv iew . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 The Yahoo Interview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10 Interview warf be Stories . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 Interview Questions. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18 Chapter 1 Chapter 2 Chapter 3 Chapter 4 Chapter 5 Chapter 6 Chapter 7 Chapter 8 Chapter 9 Chapter 10 Chapter 11 Chapter 12 Chapter 13 Chapter 14 drop Mathematics. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 Arrays & Hash Tables. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21 snatch Manipulation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23 Brain Teasers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25 C / C++ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27 Counting and Combinatorics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29 Database. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31 Debugging Existing Code. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33 Games . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 Java. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 Large Scale & Memory Limits . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39 relate Lists . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41 Low Level . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43 Matrix. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45 4 2009 CAREERCUP exclusively for emailprotected google. com Table of ContentsChapter 15 Chapter 16 Chapter 17 Chapter 18 Chapter 19 Chapter 20 Chapter 21 Chapter 22 Chapter 23 Chapter 24 Ne t failing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47 tendency Oriented Design . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49 Probability and Randomness . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51 Softw be and System Design. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53 categorisation and Searching . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55 Stacks and Queues . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57 Strings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59 Testing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 Threads And Locks . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4 Trees and Graphs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66 Solutions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69 2009 CAREERCUP 5 Practice Interviews Studying religious services, but nonhing stand prepare you similar the real social function. sever each(prenominal)y CareerCup queryer has infractn over a hundred consultations at Google, Microsoft, or Amazon. To nail your interview, dumb put set down with a trained interviewer and live their experienced feedback. See www. lifecup. om/interview for more details. One hour Interview with Real Interviewers Our interviewers volition give you a real interview, provided a uniform youd bem lend oneself at Google, Microsoft or Amazon. Well block push through you on the identical types of questions t chapeau they do. Well grade you the aforementioned(prenominal) way they do. How send word we do this? Weve d adept over deoxycytidine monophosphate interviews severally for these companies. Weve cover songed continues. Weve been part of their hiring citizens committees. We last what they essential. Well Also Give You An . mp3 recording of your interview. Feedback on whither you shined and where you struggled. Specific put forwardions on how to improve.Instructions on how to approach tough businesss Lessons on what interviewers look for in your computer edict. A ingrained Interview A typical interview includes a brief proveion of your resume and one or more technological questions. Each interview leave do coding via a shared document. When the interview is completed, well give you immediate feedback on how you did date its noneffervescent fresh in your mind. Later that day, youll pay back an mp3 of the interview to refresh your memory. Schedule Your Interview Today See http//www. careercup. com/interview for pricing and details 6 2009 CAREERCUP xclusively for emailprotected google. com The Microsoft Interview Microsoft lacks smart populate. Geeks. People who are passionate around technology. You probably wont be tested on the ins and outs of C++ APIs, but y ou will be expected to indite code on the jump on. In a typical interview, youll show up at Microsoft at some clock in the daybreak and fill out initial paper work. Youll shake mop up a short interview with a recruiter where he or she will give you a sample question. Be nice to your recruiters while they whitethorn not evaluate your technical acquirements in depth, they rear fight for you to be conductd or not.Throughout the day, youll bear around from interviewer to interviewer, visiting all(prenominal) one in their office. exercising this age to look around and proceed a feel for what the squad culture. Interviewers are not allowed to share their feedback on you with new(prenominal)(a) interviewers, due to concerns of bias. Nonetheless, legion(predicate) sources indicate that some feedback is shared. When you complete your interviews with a squad, you might speak with a hiring manager. If so, thats a corking sign It insufficiencyly means that you passed the i nterviews with a particular police squad. Its now down to the hiring manDefinitely Prepare agers decision.You might get a decision that day, or it might be a week. After one week of no word from HR, send them a mately email bringing for a precondition update. Why do you want to work for Microsoft? In this question, Microsoft wants to unwrap that youre passionate nearly technology. A slap-up answer might be, Ive been using Microsoft software as long as I commode remember, and Im au and thentically impressed at how Microsoft creates manages to create a product that is universally surpasslent. For example, Ive been using Visual Studio recently to learn game programming, and its APIs are excellent. blood how this shows a passion for technologyWhats Unique Youll lonesome(prenominal)(prenominal) r apiece the hiring manager if youve by means of well, but if you do, thats a great(p) sign emailprotected google. com 2009 CAREERCUP 7 The Amazon Interview Amazons recruiting pro cess normally begins with one or two visit screens in which you interview with a ad hoc team. The engineer who interviews you will usually drive you to write simple code and read it aloud on the knell. They will require a broad set of questions to explore what areas of technology youre familiar with. Next, you aviate to Seattle for four or five interviews with one or two teams which cave in selected you based on your resume and phone interviews.You will involve to code on a whiteboard, and some interviewers will stress an other(a)(prenominal) skills. Interviewers are each assigned a specific area to probe and may seem really dissentent from each other. They can not see other feedback until they have submitted their own and they are disapprove from talk roughlying it until the hiring butting. Amazons bar raiser interviewer is charged with takeing the interview bar high. They attend superfluous training and will interview candidates outside their root word in order t o balance out the group itself.If one interview seems importantly harder and different, thats some kindredly the bar raiser. This somebody has both significant experience with interviews Definitely Prepare and veto power in the hiring decision. You Amazon is a web-based comp both, and will meet with your recruiter at the end of the day. that means that they care to the highest degree scale. Once your interviewers have entered their feedback, they will meet to discuss it. They will be the comm building blocky devising the hiring decision. go Amazons recruiters are excellent at following up with candidates, occasionally there are delays.If you havent heard from Amazon in spite of appearance a week, we press a friendly email. Make current you prepare questions in Large Scale. You beart need a background in distributed systems to answer these questions. Just answer the question for one system and then weigh, how does your solution change with multiple data processors? Add itionally, Amazon tends to ask a lot of questions that are based in mathematics and randomness. Whats Unique The Bar Raiser, who is brought in from a different team to keep the bar high. 8 2009 CAREERCUP exclusively for emailprotected google. com The Google InterviewThere are mevery scary stories floating around closely Google interviews, but its mostly vertical that stories. The interview is not terribly different from Microsofts or Amazons. However, beca mapping Google HR can be a little disorganized, we recommend being proactive in communication. A Google engineer performs the first phone screen, so expect tough technical questions. On your onsite interview, youll interview with four to six people, one of whom will be a lunch interviewer. Interviewer feedback is kept confidential from the other interviewers, so you can be assured that you enter each interview with blank slate.Your lunch interviewer doesnt submit feedback, so this is a great opportunity to ask honest questions. Written feedback is submitted to a hiring committee of engineers to stir a lock/no-hire recommendation. Feedback is typically broken down into four categories (Analytical Ability, Coding, Experience and Communication) and you are apt(p) a score from 1. 0 to 4. 0 overall. The hiring committee understands that you cant be expected to excel in e genuinely interview, but if multiple people raise the same red flag (arrogance, unworthy coding skills, etc), that can disqualify you.A hiring committee typically wants to see one interviewer who is an en olibanumiastic endorser. In other words, a packet with scores of 3. 6, 3. 1, 3. 1 and 2. 6 is better than all 3. 1s. Your phone screen is usually not a factor in the final decision. The Google hiring process can be slow. If you siret hear back within one week, politely ask your recruiter for an update. A lack of reply says nothing about your performance. Definitely Prepare As a web-based company, Google cares about how to pattern scal able system. So, authorise sure you prepare question from Large Scale. Additionally, umpteen Google interviewers will ask questions involving bit shifting and Bit Manipulation, so please brush up on these questions. Whats Different Your interviewers do not sham the hiring decision. Rather, they enter feedback which is passed to a hiring committee. The hiring committee recommends a decision which can bethough ra swear is spurned by Google exe omissionives. emailprotected google. com 2009 CAREERCUP 9 The Yahoo Interview Resume Selection & Screening While Yahoo tends to only recruit at the top 10 20 schools, other candidates can still get interviewed finishedYahoos job board (or better yet if they can get an internal referral). If youre one of the happy ones selected, your interview process will start off with a phone screen. Your phone screen will be with a senior employee (tech lead, manager, etc). Onsite Interview You will typically interview with 6 7 people on the same te am for 45 transactions each. Each interviewer will have an area of focus. For example, one interviewer might focus on databases, while another interviewer might focus on your understanding of computer architecture.Interviews will often be composed as follows 5 proceedings General conversation. Tell me about yourself, your projects, etc. 20 transactions Coding question. For example, instrument merge sort. 20 minutes System design. For example, design a erect distributed cache. These questions will often focus on an area from your past experience or on something your interviewer is curDefinitely Prepare rently working on. Decision At the end of the day, you will likely meet with a Program Manager or someone else for a general conversation (product demos, concerns about the company, your competing offers, etc).Meanwhile, your interviewers will discuss your performance and attempt to come to a decision. The hiring manager has the ultimate say and will weigh the demonstrable feedb ack against the negative. If you have take upe well, you will often get a decision that day, but this is not forever the case. There can be many reasons that you might not be told for several days for example, the team may feel it needs to interview several other people. Yahoo, nigh as a rule, asks questions about system design, so ground sure you prepare that. They want to cognise that you can not only write code, but that you can design software. arrogatet worry if you dont have a background in this you can still reason your way through it Whats Unique Your phone interview will likely be performed by someone with more influence, such(prenominal) as a hiring manager. Yahoo is also unusual in that it often gives a decision (if youre hired) on the same day. Your interviewers will discuss your performance while you meet with a final interviewer. 10 2009 CAREERCUP exclusively for emailprotected google. com Interview War Stories The View from the Other Side of the Front, by Pete r BaileyFor the eager candidate getting bustling for a big job interview, Cracking the Technical Interview is an invaluable reference, containing excellent coaching and put material that gives you an inside edge on the interview process. However, as you go over your old data twists text hand and drill yourself with stemmade discrete math flash cards, dont make the slip ones mind of thinking of the interview as a kind of high-pressure game show that if you just give all the right answers to the tech questions, you too can win a shiny new career (this week, on Who Wants to be a Software Engineer? While the technical questions on computer skill obviously are very important, the most important interview question is not cover in this guidebook. In fact, its often the single most important question in your interviewers minds as they wicket you in that little room. Despite the questions on polymorphism and heaps and virtual machines, the question they really want an answer to is W ould I have a beer with this guy? Dont look at me like that, Im serious Well, I may be embellishing a little, but hear me out.The percentage point Im trying to make is that interviewers, especially those that you might work with, are probably just as anxious as you are. Nonsense, you say, as a nervous young shamional, construeing your pants for lint while you keenness your fingernails, postponement for the interview team to show up in the front lobby. After all, this is the big leagues, and these guys are just waiting for you to slip up so they can rip you apart, laugh at your shrivel up corpse, and grind your career dreams to dust beneath the heels of their boots. Right? Just like pledge week, back in freshman year?Right? Hmmm? Nothing could be further from the truth. The team of developers and managers interviewing you have their own tasks and projects waiting for them, back at their own desks. Believe me, theyre hoping that all(prenominal) interview is firing to be the f inis one. Theyd rather be doing anything else. There might be a batch of upcoming projects looming on their calendar, and they need more manpower if theyre going to even have a prayer of making their deadline. But the last guy the agency sent over was a complete flake who railed about Microsofts evil for fractional an hour.And the one before that couldnt code his way out of a wet paper bag without using copy-and-paste. Sheesh, they think, where is HR getting these guys? How hard can it be to hire one lousy person? While they may not literally be asking themselves Would I have a beer with this guy (or gal), they are looking to see how well you would fit in with the team, and how you would fall team chemistry. If they hire you, youre all going to be spending a lot of time together for 11 2009 CAREERCUP exclusively for emailprotected google. com Interview War Stories he adjoining few months or years, and they want to know that they can rely on you and perchance even come to consi der you a friend and colleague. They want to know that they can depend on you. And as tempting as it might be to them to just settle and hire the next person who comes on, they know better. In many companies, particularly large U. S. companies, its harder to fire somebody than it is to hire somebody. (Welcome to the US Land of Lawsuits ) If they hire a dud, theyre stuck with them. That person might be unproductive or, even worse, a drain on the teams productivity.So they keep interviewing, until they find the right person. They know that its better to reject a groovy candidate than hire a bad one. Some of those interviews are real doozies. Once youve interviewed long replete, you build up a repertoire of horror stories. War stories, of candidates who looked promising on paper until the interviews went terribly, terribly wrong. These war stories are not only humorous theyre also instructive. Names have been changed to protect the innocent or honest ridiculous. zyxwvutsrqponmlk jihgfedcba ZYXWVUTSRQPONMLKJIHGFEDCBA emailprotected google. comkjlslen 0987654321+_=-)(*&%$ ,. /? ABCDEZYXW abcdeyxw asdsasdFGJwRXGs75rpqR3oFWHMJHp-RQ. LLqJ. H-rsdkktNNsasdf emailprotected google. com emailprotected google. com 2009 CAREERCUP 12 Interview War Stories Pop Divas Need Not Apply Leonard was a very promising C++ coder, three years out of college, with a square work history and an grandiose skill set. He proved on the phone screen that he was above-average technically, and so he was invited in for an interview. We needed a savvy C++ person to work on a piece of middleware that interfaced with our database, and Leonard seemed like a sure fit.However, once we started talking to him, things went south in a hurry. He spent most of the interview criticizing every tool and platform that we questioned him on. We employ SQL Server as our database? Puhleease. We were planning to switch to visionary short, right? Whats that? Our team used Tool A to do all our coding in? Unac cep confuse. He used Tool B, and only Tool B, and after he was hired, wed all have to switch to Tool B. And wed have to switch to Java, because he really wanted to work with Java, condescension the fact that 75 percent of the codebase would have to be rewritten.Wed thank him later. And oh, by the way, he wouldnt be making any meetings before ten oclock. Needless to say, we encouraged Leonard to seek opportunities elsewhere. It wasnt that his ideas were bad in fact, he was technically right about many things, and his (strong) opinions were all backed with solid fact and sound reason (except for the ten oclock thing we think he may have just been making a power play. ) But it was obvious that, if hired, Leonard wasnt going to play well with others he would have been toxic kryptonite for team chemistry.He actually managed to offend two of the team members during the forty-five minutes of his interview. Leonard also made the mistake of assuming that Code Purity and Algorithm dishfu l were ever so more important than a business deadline. In the real world, there are always compromises to be made, and knowing how to work with the business analysts is just as important as knowing how to refactor a blob of code. If Leonard would not have gotten along with other IT people, he definitely wouldnt have gotten along with the business phratry. Maybe you can get away ith hiring a Leonard if hes one of the go around ten coders in the world (he wasnt). But he was the crystalizeic failure example for the Would you have a beer with this guy? test. 13 2009 CAREERCUP exclusively for emailprotected google. com Interview War Stories What We Have Here is Failure to Communicate Trisha was a mid-level Java developer with a solid history of middleware and JSP work on her resume. Since she was local, we invited her in for an interview without a phone screen. When we started asking her questions, it quickly became obvious that Trisha was a woman of few words.Her answers were sho rt and often composed of yes/no responses, even to questions that were meant to start a dialog. Once she did start opening up, I still wasnt sure she was actually talking. I saw her lips moving, and heard mumbling sounds coming out, but it wasnt anything that sounded like English. Im not sure if Trisha was nervous or just shy, but either way, I had to ask her numerous propagation to repeat herself. Now I was the one getting nervous I didnt want to be the guy who ruined the interview, so I pulled back on my questions. The other folks in the room and I exchanged uneasy glances.We felt like we were on a Seinfeld episode. It was almost impossible to understand Trisha, and when she did speak up, her halting, un trusted, confused speech patterns made us feel more like code breakers than interviewers. I am not exaggerating to say that I did not understand a single answer she gave during the interview. Knowing, alone, isnt good enough. Youre going to be talking with other technical people, and youre going to be talking to customers, and sales reps, and Betty from Marketing. You will write something eventually, whether its documentation, or a project plan, or a requirements document.The word processor might correct your spelling, but it wont correct your lousy opus. The ability to communicate thoughts and ideas, in a clear, concise manner, is an absolutely invaluable skill that employers seek. The same goes for verbal communication. I used to work with a co-worker who doubledd the length of every meeting he was in, because he could not answer a question in less than ten minutes. Hey, Dennis, what time is it? Well, thats kind of interesting, because I just happened to be reading an article on cesium clocks and leap seconds and the history of the Gregorian Calendar and Ill spare you the rest. emailprotected google. com 2009 CAREERCUP 14 Interview War Stories You Can Count on Me, Just Not Until Early Afternoon Ahhh, 1999. The crest of the dot-com bubble, and the ti ghtest bray market in history. Our company was racing to expand its development team, and we would have hired a German Shepherd if it knew HTML. Instead, we wound up hiring Ian. We shouldve hired the dog. Ian was a cheerful, friendly guy who had a gift of natural charisma. He got along fantastically with all of the interviewers, and seemed very intelligent.Skillwise, he was adequate. He hadnt written a single line of computer code outside of his college courses, and didnt even have his own electronic mail address. When we gave Ian the chance to ask us questions at the end of the interview, he asked about flexible work hours, and how soon he could take vacation time. Instead of showing an interest in the career opportunities, or in companys growth prospects, he asked whether he could take the all-you-could-drink break room soda home with him. The questions grew more bizarre from there. Ian was very interested in our Legal Assistance benefit.He wanted to know if it covered the cost of filing lawsuits, if it covered him if he got sued himself, if it applied to any lawsuits he currently was involved in, and if he could theoretically use it to sue the company itself. He also asked us if he could use it to uphold him fix some unpaid speeding tickets. In any other year, that should have been it for Ian right there. But, in 1999, we were hiring anybody who was even remotely competent. Ian collected paychecks from us for eighteen months, and he was about as productive as a traffic cone.He usually sauntered into the office around ten-thirty with some sort of lame excuse (by my count, he had to wait for the cable guy sixteen times in a six-month period). He usually killed the morning by answering e-mail and playing ping-pong, before breaking for a two-hour lunch. After lunch, it was more pingpong, and maybe an hour of writing bad code, before bolting the office sometime around three. He was the dictionary translation of unreliable. Remember, your potential future tea m members need to know that they can rely on you. And they need to know that you wont need eternal supervision and hand-holding.They need to know that youre able to exercise things out on your own. One of the most important messages that you, as a candidate, can convey in your interview is hiring me will make your lives easier. In fact, this is a large part of the reason for the famously tough interview questions at pips like Amazon and Google if you can bobby pin that kind of unpredictable pressure in an interview, then you stand a good chance of being useful to them on real projects. To appoint a more subtle example, once I was on a four person team that was desperately trying to recruit new members to help work on an old pile of software.It was a real mess wed inherited a nasty ball of spaghetti, and we needed people who could wipe in, figure things out, and be part of the solution. There was one very smart fellow, Terry, who would have been a great asset for our team 15 2009 CAREERCUP exclusively for emailprotected google. com Interview War Stories but we didnt hire him, disdain his excellent technical and personal skills. It was because he insisted on meticulous written instructions for every tincture of the coding process.He wasnt going to make a suggestion or take any curtain raising or blow his nose, for that matter without a mile-long audit trail and a dozen signatures. While he insisted that he worked that way for reasons of quality (a defensible point), we got the impression that it had more to do with butt-covering, and we simply didnt have the time for that kind of bureaucracy. Terry would have been an excellent fit in a government or aero spot IT department, something that require ISO 9000 procedures. But he would have never fit into our team he would have been a burden, not an asset.emailprotected google. com 2009 CAREERCUP 16 Interview War Stories My Spider Senses are Tingling I can think of lots of interviews that just fell int o the general category of weird and uncomfortable The Java coder who seemingly considered hygiene optional, and had the interview room smelling like week-old blue cheese within ten minutes (my eyes were peeing). The young fresh-out-of-college graduate with a tongue piercing that kept tick-tick-ticking against his teeth as he talked (after half an hour, it was like Chinese water torture).The girl who wore an iPod through her interview, with the volume turned loud enough that she actually had to ask the interviewers to repeat themselves a few times. The poor, hyper-nervous fellow who was sweating like a marathon runner for half an hour. The girl who wore a T-shirt with an obscene political slogan to her interview. The guy who asked (seriously) at the end of his interview, So, are there any hot chicks in our department? Those are the interviews where we politely thank the people for their time, shake their hand (except for the sweaty guy), then turn to each other after the do or closes and ask did that really just happen?Nobody is saying that you have to be a bland, boring zombie in a Brooks Brothers suit and tie. Remember, the interview team wants you to be the one, but theyre also very worried about the possibility that youre going to be more of a distraction than an asset. Dont talk or behave in a way that will set off their early warning radar. Whether or not somebody bothers to behave professionally during an interview is often a very good indicator of what kind of teammate theyre going to be. primal social skills are part of the answer to Would I have a beer with this guy? , or at to the lowest degree, Will I mind working next to this guy for six months? From the interviewers point of view, theyre picking a neighbor that theyre going to live and work with 200 hours per week for predictable future. Would you really want a neighbor that smelled like a hog rendering plant? 17 2009 CAREERCUP exclusively for emailprotected google. com Interview Q uestions Study hard, practice and good luck How this Book is Organized The interview questions in this book are grouped into categories, with a page preceding each category offering advice and other information.Within each category, the questions are sorted by approximate level of difficulty. Solutions for all questions are at the back. How to Use this Book An effective interview is not about memorizing interview questions, but rather, about retaining an understanding of concepts and demonstrating your problem solving ability. Use these questions to find the gaps in your knowledge and to learn problem solving techniques that you can apply to new questions. Advice for Devs Your interview will be most likely not be conducted on a computer. Thus, when you practice the problems in this book, we recommend writing them down on paper first.Then, type your solution into the computer exactly as you wrote it and see how you did. Special Advice for SDETs Not only do SDETs have to be great tes ters, but they also have to be great coders. Thus, we recommend that you complete the coding problems in this book with an eye for testing them. Even when the question doesnt specifically ask it, you should ask yourself, how would I test this? Remember any problem can be an SDET problem. Suggestions and Corrections While we do our best to regard that all the solutions are correct, mistakes will be made. Moreover, sometimes there is no right answer.If youd like to offer a suggestion or correction, please submit it at http// xrl. us/ccbook emailprotected google. com 2009 CAREERCUP 18 Applied Mathematics How to progression CHAPTER-1 Many of the so-called Applied Mathematics problems read as thinker teasers at first, but can be worked through in a logical way. Just remember to rely on the rules of mathematics to develop an approach, and then to guardedly translate that idea into code. Example Given two military issues m and n, write a regularity to return the first turning r th at is dissociative by both (e. g. , the least putting surface multiple).The arise What does it mean for r to be divisible by m and n? It means that all the primevals in m must go into r, and all primes in n must be in r. What if m and n have primes in common? For example, if m is divisible by 35 and n is divisible by 37, what does this mean about r? It means r must be divisible by 37. The Rule For each prime p such that pa m (e. g. , m is divisible by pa) and pb n, r must be divisible by pmax(a, b) The Algorithm limn q to be 1. for each prime bet p less than m and n find the largest a and b such that pa m and pb n let q = q * pmax(a, b) return qThings to Watch Out For 1. 2. Be careful with the difference in precision among floats vs. doubles. Dont assume that a value (such as the slope of a line) is an int unless youve been told so. Prime Numbers 1. 2. every number can be written as a product of primes. Example 504 = 23 * 32 * 7 f x is divisible by y, then every prime fac tor in y must be found in x. Example If 504 is divisible by y, then y could be 168 (23 * 3 * 7), or 21 (3 * 7), or 4 (22), or many other things. Y could not, however, be equal to 10 (5 * 2), since 5 is not found in x 19 2009 CAREERCUP exclusively for emailprotected oogle. com Applied Mathematics CHAPTER-1 1. 1 Write a method to buzz off the nth Fibonacci number _______________________________________________________________________pg 69 1. 2 Write a method to count the number of 2s between 0 and n. EXAMPLE insert 35 output 14 list of 2s 2, 12, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 32 _______________________________________________________________________pg 70 1. 3 Given two lines on a Cartesian plane, arrange whether the two lines would intersect. _______________________________________________________________________pg 74 1. Given two squares on a two dimensional plane, find a line that would cut these two squares in half. _____________________________________________________ __________________pg 75 1. 5 Write an algorithmic program which computes the number of trailing zeros in n factorial. EXAMPLE foreplay 11 output 2 (11 = 39916800) _______________________________________________________________________pg 76 1. 6 Write a hunt down that adds two numbers. You should not use + or any arithmetic operators. _______________________________________________________________________pg 77 1. Write a method to implement *, , / operations. You should use only the + operator. _______________________________________________________________________pg 79 1. 8 Design an algorithm to find the kth number such that the only prime factors are 3, 5, and 7. _______________________________________________________________________pg 81 1. 9 A circus is conception a hover routine consisting of people standing atop one anothers shoulders. For practical and aesthetic reasons, each person must be both shorter and lighter than the person below him or her.Given the heights and weights of each person in the circus, write a method to compute the largest possible number of people in such a tower. EXAMPLE Input(ht, wt) (65, 100) (70, 150) (56, 90) (75, 190) (60, 95) (68, 110) Output The longest tower is length 6 and includes from top to merchantman (56,90) (60,95) (65,100) (68,110) (70,150) (75,190) _______________________________________________________________________pg 84 1. 10 Given a two dimensional graph with 6000 points on it, find a line which passes the most number of points. ______________________________________________________________________pg 86 2009 CAREERCUP 20 Arrays & Hash Tables How to Approach CHAPTER-2 While not all problem can be solved with a hash table, a shocking number of interview problems can be. Keeping track of which items youve already seen? Hash table. Needing a way to efficiently look up data? Hash table. The list goes on and on. You should become very extremely comfortable with hash tables how to implement them and how to use them. Hash Tables A hash table is a data structure that associates depicts with values for O(1) lookup.Hash tables are frequently, though not always, implemented with an line up. A simple implementation of a hash table that hashes a string to a Person is as follows kinsperson HashTable Person data = new PersonMAX_HASH_KEY int getId(string s) /* return a key for this string */ bool contains(string key) int id = getId(key) if (data247) return true return false void insert(string s, Person p) datagetId(s) Note This implementation does not handle collision. Collisions can be handled by chaining (eg, using a tie in list), or a mannikin of other ways. Vector (Dynamically Resizing Array)A vector, or a dynamically resizing array, is an array that resizes itself as needed while still providing O(1) access. A typical implementation is that when a vector is full, the array doubles in size. Each doubling takes a long time (O(n)), but happens so rarely that its asymptotic time is still O(1). 21 2009 CAREERCUP exclusively for emailprotected google. com Arrays CHAPTER-2 2. 1 Suppose we have an array a1, a2, , an, b1, b2, , bn. Implement an algorithm to change this array to a1, b1, a2, b2, , an, bn. _______________________________________________________________________pg 87 . 2 Design an algorithm and write code to remove the duplicate characters in a string without using any additional buffer. NOTE One or two additional variables is fine. An limited copy of the array is not. FOLLOW UP Write the test cases for this method. _______________________________________________________________________pg 88 2. 3 You are given an array of integers (both positive and negative). Find the continuous sequence with the largest sum. Return the sum. EXAMPLE input 2, -8, 3, -2, 4, -10 output 5 eg, 3, -2, 4 _______________________________________________________________________pg 90 2. Design an algorithm to find all pairs of integers within an array which sum to a specif ied value. _______________________________________________________________________pg 91 2. 5 An array A1 n contains all the integers from 0 to n except for one number which is missing. In this problem, we cannot access an entire integer in A with a single operation. The elements of A are pay offed in binary, and the only operation we can use to access them is fetch the jth bit of Ai, which takes constant time. Write code to find the missing integer. Can you do it in O(n) time? ______________________________________________________________________pg 93 2009 CAREERCUP 22 Bit Manipulation How to Approach CHAPTER-3 Bit manipulation can be a scary thing to many candidate, but it doesnt need to be If youre shaky on bit manipulation, we recommend doing a couple arithmetic-like problems to boost your skills. Compute the following by hand 1010 0001 1010 1 1010 + 0110 10011001 0xFF 1 11001010 1001 & 1100 0xAB + 0x11 If youre still uncomfortable, examine very careful what happens when yo u do subtraction, addition, etc in base 10. Can you repeat that work in base 2? Things to Watch Out For Its really easy to make mistakes on these problem so, be careful When youre writing code, stop and thinking about what youre writing every couple lines. When youre done, check through your entire code. If youre bit shifting, what happens when the digits get shifted off the end? Make sure to think about this case to ensure that youre handling it correctly. 1 & 0 = 0 1 0 = 1 1 0 = 1 0 & 1 = 0 0 1 = 1 0 1 = 1 1 & 1 = 1 1 1 = 1 1 1 = 0 And (&) 0 & 0 = 0 Or () 0 0 = 0 Xor () 0 0 = 0 Left Shift x 2 = 00000110 00011001 4 = 00000001 exclusively for emailprotected oogle. com 23 2009 CAREERCUP Bit Manipulation CHAPTER-3 3. 1 Write a function int BitSwapReqd(int A, int B) to determine the number of bits required to convert integer A to integer B. EXAMPLE _______________________________________________________________________pg 94 3. 2 If you were to write a program to swap odd an d even bits in integer, what is the minimum number of instructions required? (eg, bit 0 and bit 1 are swapped, bit 2 and bit 3 are swapped, etc). EXAMPLE _______________________________________________________________________pg 95 3. 3 Write a method which finds the maximum of two numbers.You should not use if-else or any other comparison operator. EXAMPLE _______________________________________________________________________pg 96 3. 4 Given a (decimal e. g. 3. 72) number that is passed in as a string, print the binary representation. If the number can not be represented accurately in binary, print ERROR _______________________________________________________________________pg 97 3. 5 You are given two 32-bit numbers, N and M, and a two bit positions, i and j. Write a method to set all bits between i and j in N equal to M (eg, M becomes a substring of N find at i and starting j).EXAMPLE _______________________________________________________________________pg 99 3. 6 Write a func tion to swap a number in model without temporary variables. ______________________________________________________________________pg 100 3. 7 Given an integer, print the next smallest and next largest number that have the same number of 1 bits in their binary representation. ______________________________________________________________________pg 101 input N = 10000000000, M = 10101, i = 2, j = 6 output N = 10001010100 Input 5, 10 Output 10 Input 10001010 Output 01000101 Input 31, 14 Output 2 2009 CAREERCUP 24 Brain Teasers Do companies really ask headland teasers? CHAPTER-4 While many companies, including Google and Microsoft, have policies banning brain teasers, interviews still sometimes ask these tricky questions. Advice on Approaching Brain Teasers Dont panic when you get a brain teaser. Interviewers want to see how you tackle a problem they dont expect you to immediately know the answer. Start talking, and show the interviewer how you approach a problem. In many cases, you w ill also find that the brain teasers have some connection back to fundamental laws or theories of computer science.If youre stuck, we recommend simplifying the problem. operate it for a small number of items or a special case, and then see if you can popularize it. Example You are trying to cook an bombard for exactly 15 minutes, but instead of a timer, you are given two ropes which burn for exactly 1 hour each. The ropes, however, are of uneven densities eg, half the rope length-wise might take only 2 minutes to burn. The approach 1. 2. 3. 4. 5. 6. 7. What is important? Numbers usually have a meaning behind them. The fifteen minutes and two ropes were picked for a reason. SimplifyYou can easily time one hour (burn just one rope). Now, can you time 30 minutes? Thats half the time it takes to burn one rope. Can you burn the rope twice as fast? Yes (Light the rope at both ends. ) Youve now learned (1) You can time 30 minutes. (2) You can burn a rope that takes X minutes in just X/ 2 minutes by lighting both ends. Work backwards if you had a rope of burn-length 30 minutes, that would let you time 15 minutes. Can you remove 30 minutes of burn-time from a rope? You can remove 30 min of burn-time from lasso 2 by lighting Rope 1 at both ends and Rope 2 at one end.Now that you have Rope 2 at burn-length 30 min, start homework the egg and light rope 2 at the other end. When Rope 2 burns up, your egg is done 25 2009 CAREERCUP exclusively for emailprotected google. com Brain Teasers CHAPTER-4 4. 1 Add arithmetic operators (plus, minus, times, divide) to make the following construction true 3 1 3 6 = 8. You can use any parentheses youd like. ______________________________________________________________________pg 103 4. 2 You have a 5 quart jug and 3 quart jug, and an unlimited supply of water (but no measuring cups). How would you come up with exactly four quarts of water?NOTE The jugs are inquisitively shaped, such that filling up exactly half of the jug would be impossible. ______________________________________________________________________pg 104 4. 3 There is a building of 100 floors. If an egg drops from the Nth floor or above it will break. If its dropped from any floor below, it will not break. Youre given 2 eggs. Find N, while minimizing the number of drops for the worse case. ______________________________________________________________________pg 105 4. 4 A bunch of men are on an island. A genie comes down and gathers everyone together and places a magical hat on some peoples heads (e. . , at least one). The hat is magical it can be seen by other people, but not by the wearer of the hat himself. To remove the hat, you must dunk yourself underwater at exactly midnight. If there are n people and c hats, how long does it take the men remove the crowns? The men cannot tell each other (in any way) that they have a hat. FOLLOW UP Prove that your solution is correct. ______________________________________________________________________p g 106 4. 5 There are 100 closed storage lockers in a hallway. A man begins by opening all the 100 lockers. Next, he closes every second locker.Then he goes to every third locker and closes it if it is open or opens it if it is closed (eg, he toggles every third locker). After his 100th pass in the hallway, in which he toggles only locker number 100, how many lockers are open? ______________________________________________________________________pg 108 2009 CAREERCUP 26 C / C++ How To Approach CHAPTER-5 A good interviewer wont demand that you code in a language you dont profess to know. Hopefully, if youre asked to code in C++, its listed on your resume. If you dont remember all the APIs, dont worryyour interviewer probably doesnt eitherWe do recommend, however, studying up on basic C++ syntax. Pointer Syntax int p = v = Foo int *p // Defines pointer. &q // Sets p to address of q. *p // Set v to value of q. *f = new Foo() // Initializes f. k = f-x // Sets k equal to the value of fs member variable. C++ Class Syntax class MyClass private double var exoteric MyClass(double v) var = v MyClass() double Update(double v) double ComplexUpdate(double v) var = v return v C++ vs Java A very common answer in an interview is describe the differences between C++ and Java. If you arent comfortable with any of these concepts, we recommend reading up on them. 1. 2. 3. 4. 5. 6. Java runs in a virtual machine. C++ natively supports unsigned arithmetic. In Java, parameters are always passed by value (or with objects, their references are passed by value). In C++, parameters can be passed by value, pointer, or by reference. Java has built-in food waste collection. C++ allows operator overloading. C++ allows multiple inheritance of classes. Thought Which of these might be considered strengths or weaknesses of C++ or Java? Why? In what cases might you choose one language over the other? 7 2009 CAREERCUP exclusively for emailprotected google. com C / C++ CHAPTER-5 5. 1 Wha t is the difference between a struct and a class? Where would you use each? ______________________________________________________________________pg 109 5. 2 Write a method to print the last ten lines of an input file using C. ______________________________________________________________________pg 110 5. 3 Compare and contrast a hash table vs. an STL map. How is a hash table implemented? If the number of inputs are small, what data structure options can be used instead of a hash table? _____________________________________________________________________pg 111 5. 4 How do a virtual functions work in C++? ______________________________________________________________________pg 112 5. 5 What is the difference between deep copy and shallow copy? Explain how you would use each. ______________________________________________________________________pg 113 5. 6 In a class, the new operator is used for allocating memory for new objects. Can this be done using malloc? If yes, how? If no, w herefore not? Are there any restrictions associated with the use of malloc in place of new? _____________________________________________________________________pg 114 5. 7 What is the significance of the keyword volatile in C? ______________________________________________________________________pg 115 5. 8 What is name covert in C++? ______________________________________________________________________pg 116 5. 9 Why does a destructor in base class need to be declared virtual? ______________________________________________________________________pg 117 5. 10 Write a method that takes a pointer to a boss structure as a parameter and returns a complete copy of the passed-in data structure.The Node structure contains two pointers to other Node structures. For example, the method signature could look like so Node* Copy(Node* root) Note Do not make any assumptions about the data structure it could be a tree, linked list, graph etc. Feel free to choose the language you are most comf ortable with (C or C++ are preferred) In addition to the function code, write a complete suite of unit tests for this problem. ______________________________________________________________________pg 119 5. 11 Write a smart pointer (smart_ptr) class. _____________________________________________________________________pg 120 2009 CAREERCUP 28 Counting and Combinatorics How to Approach CHAPTER-6 While some problems in this chapter are simply coding problems, understanding the mathematical solution will help you sanity check your solution. For example, if you know how many subsets there are of a set, you can check to make sure that your algorithm to print all subsets will give you the correct number of subsets. When computing the number of ways of doing something, think about doing it step by step. The following two examples will illustrate this technique.How many ways can you pick k elements from n elements, if order matters and elements are not replaced? Eg if we pick 5 different letters, abcde is considered to be different from edcba. The Approach We have n choices for the first draw. For the second draw, we only have n-1 since one is removed. Then n-2, . When we draw k times, we get down to n-k+1 choices on the last draw. So, n * (n-1) * (n-2)* * (n-k+1) The Solution n / (n-k) How many ways can you pick k elements from n elements, if order does not matter and elements are not replaced? Were now just throwing letters into a bucket. Picking a, b is the same thing as b, a.The Approach If you compare this problem to the previous one, weve essentially double (or triple, quadruple, etc) counted items. That is, abc, acb, bac, bca, cab, cba were all considered unique in the previous solution but now theyre considered the same. Just how many times has abc been included (in its other forms)? 3 times, since there are 3 ways of rearranging abc. In fact, every item has been included 3 times, when it should have been included just once So, we divide our previous answer by 3 (or, more generally, k ). We now get n / (k * (n-k) ). This solution is often written as n-choose-k or nCk. 9 2009 CAREERCUP exclusively for emailprotected google. com Counting and Combinatorics CHAPTER-6 6. 1 In how many different ways can a cube be painted by using three different colors of paint? ______________________________________________________________________pg 121 6. 2 Imagine a robot seance on the upper left hand corner of an NxN grid. The robot can only move in two directions right and down. How many possible paths are there for the robot? FOLLOW-UP Imagine certain squares are off limits, such that the robot can not step on them. Design an algorithm to print all possible paths for the robot. _____________________________________________________________________pg 122 6. 3 Write a method to compute all permutations of a string. ______________________________________________________________________pg 123 6. 4 Implement an algorithm to print all valid (eg, properly o pened and closed) combinations of n-pairs of parentheses. EXAMPLE input 3 (eg, 3 pairs of parentheses) output ()()(), ()(()), (())(), ((())) ______________________________________________________________________pg 124 6. 5 Write a method that returns all subsets of a set. ______________________________________________________________________pg cxxv 2009 CAREERCUP 30 Database How to Approach CHAPTER-7 You could be asked about databases in a variety of ways write a SQL query, design a database to hold certain data, or to design a large database. Well go through the latter two types here. Small Database Design Imagine you are asked to design a system to represent a schools registrar course information, departments, course enrollment, teachers, etc. What are the key objects? Student. Professor. Course. Department. How do they relate to each other? *NOTE Im going to make some assumptions here for the purposes of writing up this explanation.In your interview, dont make assumptions deal y our interviewer instead. Many-to-Many A course can depart to multiple departments, and each department can have multiple courses. So, create a separate table DepartmentCourse that acts as a pairing of the two. DepartmentCourse has just a department_id field and a course_id field. A student can be in multiple courses, a course can have multiple students. So, do the same as above and create a StudentCourse table. A course only has one prof. A professor can teach multiple courses. So, add a field professor_id to the Courses table. One-to-Many Large Database Design When designing a large, scalable database, joins (which are required in the above examples), are generally very slow. Thus, you must denormalize your data. mobilize carefully about what when data will be usedyoull probably need to duplicate it in multiple tables. 31 2009 CAREERCUP exclusively for emailprotected google. com Database CHAPTER-7 7. 1 Write a method to find the number of employees in each department when we h ave the following tables ______________________________________________________________________pg 126 7. 2 What are the different types of joins?Please explain how they differ and why certain types are better in certain situations. ______________________________________________________________________pg 127 7. 3 What is normalization? Explain the pros and cons. ______________________________________________________________________pg 128 7. 4 Draw a entity-relationship diagram for a database with companies, people, and professionals (people who work for companies). ______________________________________________________________________pg 129 7. 5 You have to design a database that can store terabytes of data. It should support efficient range queries. How would you do it? _____________________________________________________________________pg 130 Employees containing Emp_ID, Emp_Name and Dept_ID (Primary key) Departments containing Dept_Name and Dept_ID (foreign key) 2009 CAREERCUP 3 2 Debugging Existing Code How to Approach CHAPTER-8 Sometimes, in an interview, an interviewer asks you to look at a piece of code and identify the mistakes. We recommend the following approach 1. 2. 3. Examine the code and understand what its expected to do. Ask your interviewer what types of data its expected to handle, where itll be used, etc. hold off for syntax errors does everything type check? s the class declaration correct? Look for hot spots 4. 5. If you see float and doubles, check for precision errors If you see division, check for rounding errors If you see memory allocation, check for memory leaks If you see unsigned ints, check to see if the int might ever be negative If you see bit manipulation, check for correctness The normal case The boundary cases (null, 0, 1, MAX, etc) Run through the code with a few examples Does it do everything its expect to? For example, if the code is supposed to return everyone in a database under 21, does it only look for students ?Maybe it should be looking for teach-ers as well? Does it handle unexpected cases? What if it takes in a list and it has a loop? 6. Further Advice 1. 2. Look at the space and time complexitycan you improve it? Correct the mistakes in the code. But do so carefully Dont simply make changes until it works. Deeply understand the issues and then correct them. 33 2009 CAREERCUP exclusively for emailprotected google. com Debugging Existing Code 8. 1 Explain what the following code does ((n & (n-1)) == 0) CHAPTER-8 ______________________________________________________________________pg 131 8. Find the mistake(s) in the following code unsigned int i for (i = 100 i Other int foo() printf(here we are ) main() typedef Foo typedef Derived Derived_inst Derived_inst ii ii. foo() ______________________________________________________________________pg 133 2009 CAREERCUP 34 Games How To Approach CHAPTER-9 Sometimes interviewers ask these problems simply because theyre fun, but often, its a lso because game problems are enceinte on object oriented design. Gaming problems tend to be more free form and thus they give you the chance to demonstrate how you really code.Define Data Structures When implementing something so free form, ask yourself, Where can I define a class or a struct? When in doubt, define a new class or struct. It tells the interviewer that you care about the maintainability of your code. Validate Your Assumptions Be careful about making assumptions. Suppose youre asked to implement the word game Scrabble. Dont assume that the dictionary will be in Englishor even in that character set. It could be in any language Ask your interviewer lots and lots of questions so that you know what to implement. Are you solving this problem once, or many times?Sometimes the solution will change depending on whether or not your code will be called multiple times. For example, suppose youre asked to find all anagrams of a word. If youre calling this code just once, it may be fastest just to rearrange the letters and check if theyre in the dictionary. But, if youre going to call the code multiple times, its now fastest to precompute data by iterating through all the words in the dictionary. Can you generalize your code, or part of it? If you really want to go above and beyond, try writing your code as though it were a more reason case.For example, if youre trying to figure out if a tic-tac-toe board has a winner, you might suggest to your interviewer solving it for the more general NxN case. If you go down this path though, be warnedsometimes problems are trickier than they appear. Also, make sure you discuss this with your interviewer so he/she knows what youre doing. 35 2009 CAREERCUP exclusively for emailprotected google. com Games CHAPTER-9 9. 1 Design an algorithm to figure out if someone has won in a game of tic-tac-toe. ______________________________________________________________________pg 135 9. The Game of headmaster Mind is played as f ollows The computer has four slots containing balls that are red (R), yellow (Y), green (G) or blue (B). For example, the computer might have RGGB (eg, Slot 1 is red, Slots 2 and 3 are green, 4 is blue). You, the user, are trying to imagine the solution. You might, for example, guess YRGB. When you guess right color for the right slot, you get a hit. If you guess a color that exists but is in the wrong slot, you get a psuedo-hit. For example, the guess YRGB has 2 hits and one pseudo-hit. For each guess, you are told the number of hits and pseudo hits.Write a method that, given a guess and a solution, returns the number of hits and pseudo hits. ______________________________________________________________________pg 137 9. 3 There is an 88 cheater board in which two diagonally opposite corners have been cut off. You are given 31 dominoes in which a single domino can cover exactly two squares. Can you use the 31 dominos to cover the entire board? Prove your answer (by providing a n example, or showing why its impossible). ______________________________________________________________________pg 138 9. Find a way to arrange 8 queens on a chess board so that none of them share the same row, column or diagonal. ______________________________________________________________________pg 139 9. 5 Othello is played as follows Each Othello piece is white on one side and black on the other. On your turn, you place a piece on the board so that your color is facing up. You must pick a spot such that your opponents pieces are either on the left and the right, or on the top and the bottom. All of your opponents pieces on the line between two of yours are then turned over, to become yours. Your goal is to own the most pieces.Design the game Othello. Write a method to check whether someone has won the game. ______________________________________________________________________pg 141 2009 CAREERCUP 36 Java How to Approach CHAPTER-10 While Java related questions are found thro ughout this book, this chapter deals with questions about the language and syntax. You generally will not find many questions like this at the larger software companies (Microsoft, Google, Amazon, etc), which tend to avoid trivia based questions, but these questions are very common at many smaller companies. What do you do when you dont know the answer?If you dont know the answer to a question about the Java language, try to figure it out by doing the following (1) Think about what other languages do. (2) Create an example of the scenario. (3) Ask yourself how you would handle the scenario if you were designing the language. Your interviewer will likely be equallyor moreimpressed if you
Subscribe to:
Post Comments (Atom)
No comments:
Post a Comment
Note: Only a member of this blog may post a comment.