Exams
Final Exam
- Date: Thursday, March 17, 2011
- Time: 2:30 - 4:20pm
- Place: Kane 120 (our normal lecture room)
- Materials allowed: pencil/pen, Building Java Programs textbook (we will provide scratch paper and a "cheat sheet")
Regrades:
The final exam follows the same regrade policy as the midterm exam (see below). A cover sheet and Practice-It output is required for a final exam regrade. You can slide your final under Marty's office door with the proper cover sheets attached. Regrades will be accepted through the end of the first week of Spring 2011 quarter. Regrades take a lot of time and energy; please submit a regrade only if you have a valid reason for doing so, based on an improper or overly harsh grading of a particular problem, and not simply out of dissatisfaction with your score or course grade. Recall that regrades sometimes lead to lower scores if undeducted mistakes are found while regrading your exam.
Practice Exams:
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. You may also want to time yourself to practice your pacing. Then once you have completed the paper exam, check the answer key or type in any problems you like into the Practice-It system to see whether you solved them correctly.
- Sample final exams posted here are intended to be very similar to the actual final exam. The number of problems and type of problems on the actual exam will be much like what is seen on these practice exams.
- The following topics are guaranteed NOT to be explicitly tested on the final exam:
- detailed knowledge of Big-Oh (some questions may ask you to solve them within a certain big-Oh limit, but mainly this is just to ward off extremely inefficient answers)
- recursive backtracking (recursion will definitely be needed, but not specific backtracking problems)
- 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 <T>)
- hashing
The questions on the final exam will be the following. Each question will be worth between 10-20 points:
- Polymorphism: 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 20 problems)
- Inheritance/Comparable programming: Given an existing class, write a complete subclass of it that adds certain features. Also make the class Comparable based on a given set of comparison criteria. (similar to section 17,18 problems)
- Linked list programming: Add a method to the LinkedIntList class from lecture. (similar to section 8, 19 problems)
- Searching and sorting: Trace the execution of binary search, selection sort, and merge sort on given arrays of integers.
- Binary search trees: Given a set of values, add them to a binary search tree. Then perform traversals in the three standard orders on that tree. (similar to section 15 problems)
- Binary tree programming: Add a method to the IntTree class from lecture. (similar to section 15, 16 problems)
- Binary tree programming: Add a method to the IntTree class from lecture. Similar in spirit to the previous question but harder.
Additional Sample Problems:
If you are a real practice problem junkie and want even MORE problems, here are links to a few other past exams. They don't exactly match the current exam format, and they are not in our Practice-It system, so they may be of limited use. Some of the problems on these tests don't match the topics, difficulty level, and/or type of questions we currently plan to ask. These links are provided merely as a convenience.
Midterm Exam
Scores, Curve, and Other Information:
You can now check your midterm score on MyUW. If you don't see your midterm score on your MyUW page, follow our MyUW directions.
The mean (average) score was 77.3 and the median (middle) score was 81. These scores are high enough to meet our desired target scores, therefore there will be no curve on the midterm.
Stats:
stat | value |
MEDIAN | 81 |
AVG | 77.3 |
STDEV | 17.6 |
grade | count | % of class |
As (90-100) | 119 | 28.4% |
Bs (80-89) | 112 | 26.7% |
Cs (70-79) | 79 | 18.9% |
Ds (60-69) | 46 | 11.0% |
Es (0-59) | 63 | 15.0% |
question | average score |
Q1 (ArrayList mystery) | 16.4 / 20 |
Q2 (Recursive tracing) | 17.7 / 20 |
Q3 (Stacks and queues) | 11.8 / 15 |
Q4 (Collections) | 10.7 / 15 |
Q5 (Linked lists) | 10.1 / 15 |
Q6 (Recursion) | 10.7 / 15 |
Student questions: You will get your midterm back in section. If you have questions about exactly what you missed and why, please get your exam from your TA and look it over, then contact the TA if you still have any questions.
Low Grades: Another topic some students ask about is: If their score was lower than they hoped, how much effect will that have on their grade, or what are their options, etc.? Most of the information to answer this can be found on this web site. The course syllabus lists the relative grading weight of homework vs. midterm vs. final exam, so you can use that to compute the rough effect on your grade of a particular midterm score. You may want to use our new Grade-a-nator page to help you compute your approximate grade. Also look at our FAQ page for info about S/NS grading options, drop dates, and other information.
Regrades: We work hard to grade consistently and correctly, but sometimes we make mistakes in grading. See the instructions below about how to request a regrade on your exam if you think anything was not graded accurately.
We will soon post a solution key and post the midterm problems on our Practice-It tool so that you can test your answers.
Regrade Policy:
If your exam score was added up incorrectly, take it to your TA and they'll fix it for you.
If you disagree with the grading, such as if you think your solution actually does work, or that your solution is more nearly correct than it was given credit for, the procedure for regrades is the following:
- If your complaint is about the correctness of your solution to a programming question, go to our Practice-It! system, which will contain runnable testers for the midterm problems. Type your code into Practice-It, fixing any trivial syntax problems. Run it for yourself and see how nearly correct your solution is.
- If you still think your grade is incorrect, submit your exam to Marty for a regrade. (Either give it to us in lecture, go to our office hours, or slide it under our office doors.) You must include a cover page with a brief written explanation of what specifically you think was misgraded and why. If your complaint is about overly harsh grading on a programming question, you should also submit a printout of your code being run in Practice-It, along with the test case results, to us so that we can to verify its correctness. We will not accept any exam for a regrade unless it includes this cover page, and we will not re-evaluate grading of the correctess of any programming questions without a typed copy of your solution from Practice-It being shown to us first.
- Also note: When you submit an exam for a regrade, we will regrade your entire exam. If we notice anywhere that you were mistakenly given too many points, we will also correct this, up to a maximum penalty of -2 for the entire exam. So it is possible (though unlikely) that a regrade request will result in you receiving a slightly lower mark than what you started with.
- All midterm regrade requests (other than simple score addition errors) must be submitted to the instructor by Friday, February 25, 2011.
-
" cheat sheet" (will be given out attached to your exam as a reference; bring your textbook to reference any other Java syntax/libraries)
Time/Place:
- Date: Friday, February 11, 2011
- Time: in lecture, 50 minutes
- Place: in normal lecture room, KANE 120
Practice Exams:
-
practice midterm #1
-
practice midterm #2
-
practice midterm #3
-
practice midterm #4
-
practice midterm #5 (this will be given out as Section 12's handout)
-
More practice problems can be found in the textbook and in our Practice-It! tool; also, more practice exam problem links are found below. (Note: The exams in Practice-It contain additional problems about "Comparable" and "sorting" that you may skip.)
- Sample midterm exam(s) posted here are intended to be very similar to the actual midterm. The number of problems and type of problems on the actual exam will be much like what is seen on these practice exams. Material from Weeks 1-6 is considered "fair game" for questions on the actual midterm.
The actual midterm exam will have roughly 6 total problems. Those problems will be selected from the following kinds of questions:
-
ArrayList
"mystery" (look at a piece of code that uses ArrayList
s, and write its output)
-
ArrayList
programming (write a method that uses ArrayList
s)
-
Collection programming (write a method that uses Java collections such as
List
s, Set
s, and Map
s)
-
stack and queue programming (write a method that uses
Stack
s and Queue
s)
-
linked list node manipulation (write a few lines of code to change a "before" picture of some linked nodes into an "after" picture)
-
linked list programming (add a method to the
LinkedIntList
class from lecture)
-
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:
- Java I/O, file processing,
Scanner
- programming with inheritance (extending a class, etc.)
- writing an interface (though you might have to write a method that accepts a parameter of interface type, such as
List
, Set
, Map
, etc.
- JUnit
- testing, debugging, commenting
- grammars
Iterator
- binary search
- sorting
Comparable
Additional Sample Problems:
If you are a real practice problem junkie and want even MORE problems, here are links to a few other past exams. They don't exactly match the current exam format, and they are not in our Practice-It system, so they may be of limited use. Some of the problems on these tests don't match the topics, difficulty level, and/or type of questions we currently plan to ask. (For example, a lot of these exams ask problems about inheritance and about arrays.) These links are provided merely as a convenience and as another study aid.
Rules and Information:
- You must show your UW Student ID card to a TA or the instructor for your submitted exam to be accepted.
- You will have 50 minutes to complete the exam. You may receive a deduction if you keep working after the instructor calls for papers.
- The exam is open-book for the Building Java Programs textbook, but closed-notes and closed for all other resources. You may not bring or use any other books or printed materials such as handouts, slides, or practice exams. (A "cheat sheet" of necessary syntax will be given to you at the exam.) You must work alone and may not use any computing devices of any kind including calculators. Cell phones, music players, and other electronic devices may NOT be out during the exam for any reason.
- Unless a question specifically mentions otherwise, your 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 don't need to write any
import
statements in your exam code.
- On the exam it will be allowed to abbreviate
S.o.p
for System.out.print
and S.o.pln
for System.out.println
. Otherwise do not abbreviate any code on the exam.
- Please be quiet during the exam. If you have a question or need, please raise your hand.
- Corrections or clarifications to the exam will be written at the front of the room.
- If you violate the University Code of Conduct during the exam, you may receive a 0% for the exam and possibly further punishment.
- When you have finished the exam, please turn in your exam quietly and leave the room.
- If you enter the room, you must turn in an exam paper and will not be permitted to leave the room without doing so.