There will be two in-person, timed exams in CSE 143E this quarter. The exams will be on the following dates
- Midterm: Wednesday 2/16 from 5:00 pm - 6:00 pm in KNE 120.
- Final: Tuesday 3/15 from 2:30 pm - 4:20 pm in KNE 120.
If you will not be able to make these posted exam times, please contact Hunter on Ed as soon as possible to identify an alternative.
Note
We are going to be holding the exams in KNE 120 this quarter, which has far more seats (440) than there are students in the class (170) to allow us to spread students out as much as possible.
Exam Rules and Information¶
Seating Assignments KNE 120 Map
- If you are sick, you should not attend the exam. You need to contact Hunter before the exam begins to arrange an accommodation for a make-up exam due to sickness. You do not need to provide medical documentation or proof of a negative test. If you’re sick, you need to stay home.
- Students and staff must wear their masks at all times during the exam. There is a hydration exemption where you can briefly move aside your mask to drink water. This is only permitted as long as your mask is only briefly not covering your face.
- You will have an assigned seat and you must sit in that seat. If you arrive for the exam and find someone else in your seat, ask them to move because we will move students to their assigned seats. We will take pictures of the room to help us verify that students sit in their assigned seats (please contact us if you have a concern about this). Students are expected to make a reasonable effort to sit in their assigned seat. Students who demonstrate an egregious disregard for the seating assignments will receive a 5-point penalty (e.g., if a student goes to the wrong room or refuses to move when asked to).
- We may ask to check your UW ID card during the exam so please have it ready.
- You will have 60 minutes to complete the midterm and 110 minutes to complete the final. We will distribute the exam early and you can read and fill out the cover page of the exam, but you should not look at the exam questions until you are told to begin. At the end when time is called, you are required to stop writing and close your exam. Students who look at the exam before being told to begin and students who make changes to their exam after time is called will receive a 10-point penalty. Students who do not close their exam booklet when time is called may also receive a 10-point penalty.
- The exams are closed-book and closed-note. You must work alone and may not use any computing devices of any kind including calculators or digital copies of the textbook. Cell phones, music players, and other electronic devices may NOT be out during the exam for any reason.
- There will be a cheat sheet included as the last page of the exam. Space will be provided for your answers. If you need additional scratch paper, raise your hand and a TA will give it to you. You are not allowed to use your own paper during the exam.
- Unless a question specifically mentions otherwise, the code you write will be graded purely on external correctness (proper behavior and output) and not on internal correctness (style). So, for example, redundancy or lack of comments will not reduce your score. You are, however, required to declare all data fields as private, to use generics properly, and to declare variables and parameters using interfaces when possible. The midterm cheat sheet mentions important restrictions on stacks and queues that you must follow.
- Unless otherwise specified, you should write each solution as a public instance method. You may define helper methods as part of your solution, but they should be declared to be private.
- You are allowed to abbreviate “compiler error” and “runtime error” for the inheritance question on the final (as in “ce” and “re” or “c.e.” and “r.e.”) and “S.o.p” or “S.o.pln” for printing, but you should otherwise NOT use any abbreviations on the exam.
- You don’t need to write any import statements in your exam code.
- You are not allowed to use advanced material to solve exam problems. In general, you are restricted to the classes and methods listed on the exam cheat sheet. You are not allowed to use break, continue, a return from a void method, try/catch, or Java 8 features.
- For standard Java classes such as Math and String, you are limited to the methods listed on the cheat sheet. You are not allowed to use the Arrays or Collections classes or other standard classes and methods that aren’t included on the cheat sheet.
- Please be sure that your answer is clearly indicated. This is particularly important if you provide more than one answer or if you have notes in addition to your answer. You can draw a box around the answer you want to have graded and you can draw an “X” through anything that you do not want to have graded.
- You do not need to turn in scratch paper unless you have all or part of an answer on that sheet of paper (you can take the other sheets of paper with you). If you have a sheet of paper with all or part of an answer, please write your name on that sheet of paper, staple the entire sheet to the end of your test (not in the middle) with a single staple in the upper-left corner, and clearly indicate under the corresponding problem that your answer is attached on an extra sheet of paper. A stapler will be available.
- Please be quiet during the exam. If you have a question or need assistance, please raise your hand.
- When you have finished the exam, please turn in your exam quietly and leave the room.
- You should not leave the exam room in the last 5 minutes of the testing period to avoid disruption during the final moments of the exam.
After Final Exam¶
You can find your feedback on Gradescope. Please make sure you know how to read the Gradescope criteria before asking the course staff about your grade. Your score on Gradescope already includes the extra credit opportunities.
The exam key can be found here.
The final average was a 65.3 and the median was 69.5. Please see the Ed announcement for more information about the exam.
If you think there was a mistake in grading the exam, you can submit a regrade request. Please see the Exam Regrade page for information about how to submit a regrade. There are also programs included on that page that let you test your solution. In particular for the Midterm, regrades can’t be submitted before Thursday, 2/24 at 8am and cannot be submitted after Friday, April 1st at 11:59 pm.
Final Exam¶
Final Exam Extra-Credit¶
There will be two small extra credit opportunities for the final exam. One before the exam and one during the exam. Each one is worth 1 point of extra credit that will be added to your final exam score. You can complete either one or both of these if you choose for up to a total of 2 points of extra credit.
-
The first extra-credit opportunity for the final that can be completed before the exam. The focus of this exercise is to help you explicitly practice the skill of metacognition. To receive credit, you will need to reflect on plan to prepare for the exam and think about how you might do so differently than the midterm. The ultimate goal here is to help you identify how to best adapt your study strategy for the final (and for your future classes).
For this opportunity, you should make a good-faith effort to complete the Pre-Final Preparation Survey on Canvas by Wednesday, March 9th at 11:59 pm. There are no correct answers for this quiz, it is graded on completion and effort. It should take about 15 minutes to complete.
-
There will also be a extra credit question on the final exam itself that you can complete during the exam itself. The question is short and designed to be fun. Putting non-trivial effort on this question is worth 1 point of extra credit.
Final Content¶
The questions on the final exam will be selected from the following. Each question will be worth between 5-20 points:
- Binary Tree Traversals
- What is it? Perform pre-order, in-order and post-order traversals on a tree
- What’s an example? traversal2
- Binary Search Trees
- What is it? Given a set of values, add them to a binary search tree
- What’s an example? Mew/Pikachu/Zubat/Ditto from Old Exam Database
- Polymorphism mystery
- What is it? Given a set of classes with inheritance relationships, a set of variables declared using those classes, and a set of method calls made on those variables, write the output (similar to section 3/1 problems)
- What’s an example? FeeFieFoFum
- Note: In the case the answer is an error, you will be asked to identify if the error is a run-time error or a compiler error.
- Comparable programming
- What is it? Write a complete class and make it Comparable based on a given set of comparison criteria.
- What’s an example? Location
- Note: You will not be asked to extend another pre-existing class like some problems seen on past exams
- Collections programming
- What is it? Write a method that uses one or more class from the Java Collections framework (with focus on Sets, Maps and Lists).
- What’s an example? commonHobbies from Old Exam Database
- Binary tree programming
- What is it? Add a method to the IntTree class from lecture
- What’s an example? numEmpty
- Binary tree programming
- What is it? Add a method to the IntTree class from lecture. Similar in spirit to the previous question but more challenging
- What’s an example? completeToLevel
- Linked list programming
- What is it? Add a method to the LinkedIntList class from lecture
- What’s an example? removeRange
The following topics are guaranteed NOT to be explicitly tested on the final exam:
- detailed knowledge of Big-O (some questions may ask you to solve them within a certain big-O limit, but mainly this is just to ward off extremely inefficient answers)
- detailed knowledge of search/sort algorithms
- tracing or writing code with 2-D arrays
- catching exceptions
- priority queues
- input/output streams
- abstract classes
- inner classes
- implementing an Iterator class
- implementing a “generic” class (one that accepts type parameters such as
) - hashing
- extending a pre-existing class for the Comparable problem
Final Resources¶
- Studying Tips We strongly suggest that you try to solve all of these problems yourself, on paper, without a computer, and without looking at the answer key until you’re done. A very important skill to doing well on the test is being able to look at your solution and figure out if it works without relying on a computer or the answer key since you will have neither of those available during the test.
- Sample Cheat Sheet will be provided as the last page of the exam and you are only allowed to use methods and classes shown on the cheat sheet on the exam. This is a sample cheat sheet from a previous quarter which is a good example, but some specific methods/classes may be added or removed.
- TA midterm strategies
- Old exam question database
- PracticeIt!
- Note: Practice-It! has many full CSE 143 midterms which can be great to practice to help you with timing, but be careful since these exams are quite old and have problem types that are guaranteed to not be on your exam; great examples of this are inheritance and programming LinkedIntList with loops. If you are curious what is and will not be on the exam, re-read the section above.
- Full sample midterms that are more representative of what you will see on the exam. Exams are ordered from least recent to most recent. You should save these for last so you can use them to time yourself. Sample Final 5 and and the soon-to-be-posted Sample Final 6 are the most recent exams of mine, which make them the best resources to test yourself with last. Keys will be posted after Wednesday March 9th.
- Sample Final 0 (Solution)
- Problem 4 missing is intended
- Sample Final 1 (Solution)
- Sample Final 2 (Solution)
- Ignore question related to 2D arrays
- Sample Final 3 (Solution)
- This is an exam from a summer quarter, where the exam is taken in two halves.
- Sample Final 4 (Solution) 18au’s exam
- Sample Final 5 (Solution)
- Sample Final 6 (Solution)
- Sample Final 0 (Solution)
After Midterm Exam¶
You can find your feedback on Gradescope. Please make sure you know how to read the Gradescope criteria before asking the course staff about your grade.
The exam key can be found here.
The midterm average was a 69 and the median was 71. Please see the Ed announcement for more information about grades and their adjustment. Do note that the midterm is worth 20% of your grade - that means about 50% of your grade is still to be determined! If the midterm didn’t go as well as you would have liked, come talk to the course staff about study tips and exam approaches to use on the final.
If you think there was a mistake in grading the exam, you can submit a regrade request. Please see the Exam Regrade page for information about how to submit a regrade. In particular for the Midterm, regrades can’t be submitted before Thursday, 2/24 at 8am and cannot be submitted after Thursday, 3/3 at 11:59 pm.
Midterm Exam¶
The Midterm is Wednesday 2/16 from 5:00 pm - 6:00 pm in KNE 120.
Midterm Content¶
Material from Weeks 1-5 is considered “fair game” for questions on the midterm. The actual midterm exam will have 6-8 total problems. Those problems will be selected from the following kinds of questions (and no other kinds of questions):
- ArrayIntList programming (add a method to the
ArrayIntList
class from lecture) - Collection programming (write a method that uses Java collections such as
Lists
,Sets
, andMaps
) - Stack and Queue programming (write a method that uses Stacks and Queues)
- Linked list node manipulation (write a few lines of code to change a “before” picture of some linked nodes into an “after” picture; this is NOT the problems where you have to use loops and writing for the LinkedIntList class)
- Recursion tracing (look at a piece of recursive code, and write its output)
- Recursion programming (write a method that uses recursion)
- The following topics are guaranteed NOT to be required to solve any problem on the midterm:
- exhaustive search and recursive backtracking
- programming with inheritance (extending a class, etc.)
- Inheritance/Polymorphism mystery
- writing an interface (though you might have to write a method that accepts a parameter of interface type, such as List, Set, Map, etc.
- testing, debugging, commenting
- grammars
- implementing Comparable (though you may have to be a client of TreeSet and/or TreeMap which require the elements to be comparable)
- implementing sorting algorithms (though you may have to be a client of TreeSet and/or TreeMap which maintains the elements in sorted order
- hashing
Midterm Resources¶
- There will be a review session in class on Monday 2/14 and in section on Tuesday 2/15.
- Sample Cheat Sheet will be provided as the last page of the exam and you are only allowed to use methods and classes shown on the cheat sheet on the exam. This is a sample cheat sheet from a previous quarter which is a good example, but some specific methods/classes may be added or removed.
- TA midterm strategies
- Old exam question database
- PracticeIt!
- Note: Practice-It! has many full CSE 143 midterms which can be great to practice to help you with timing, but be careful since these exams are quite old and have problem types that are guaranteed to not be on your exam; great examples of this are inheritance and programming LinkedIntList with loops. If you are curious what is and will not be on the exam, re-read the section above.
- Full sample midterms that are more representative of what you will see on the exam. You should save these for last so you can use them to time yourself. Sample Midterms 5 and 6 are the most recent exams of mine, which make them the best resources to test yourself with last.