Course Staff and Office Hours
Here are some common types of questions and the best place to ask them to get the fastest and most accurate response.
Prerequisite Material
To better assess if CSE 121 is the right class for you, the Allen School has developed a Self-Guided Placement to help students assess which intro course is the right one for them to enroll in. Please see this website for more information on who to contact if you have questions about which introductory CSE course is the right course for you.
Programming Language
CSE 121 is taught in the Java programming language. No prior experience in Java is required.
CSE 121 is designed around a set of 7 learning objectives. At the end of the course, successful students will be able to do the following:
All students are welcome in CSE 121 and are entitled to be treated respectfully by both classmates and the course staff. We strive to create a challenging but inclusive environment that is conducive to learning for all students. If at any time you feel that you are not experiencing an inclusive environment, or you are made to feel uncomfortable, disrespected, or excluded, please report the incident so that we may address the issue and maintain a supportive and inclusive learning environment. You may contact the course staff or the CSE academic advisors to express your concerns. Should you feel uncomfortable bringing up an issue with a staff member directly, you may also consider sending anonymous feedback or contacting the UW Office of the Ombud.
We recognize that our students come from varied backgrounds and can have widely-varying circumstances. We also acknowledge that the circumstances of this particular quarter may bring unique challenges. If you have any unforeseen circumstances that arise during the course, please do not hesitate to contact the course staff or the instructors to discuss your situation. The sooner we are made aware, the more easily we can provide accommodations.
Typically, extenuating circumstances include work-school balance, familial responsibilities, health concerns, or anything else beyond your control that may negatively impact your performance in the class. Additionally, while some amount of “productive struggle” is healthy for learning, you should ask the course staff for help if you have been stuck on an issue for a very long time.
Life happens! While our focus is providing an excellent educational environment, our course does not exist in a vacuum. Our ultimate goal as a course staff is to provide you with the ability to be successful, and we encourage you to work with us to make that happen.
Your experience in this class should not be negatively-affected by any disabilities that you may have. The Disability Resources for Students (DRS) office can help you establish accommodations with the course staff.
If you have already established accommodations with DRS, please communicate your approved accommodations to the lecturer at your earliest convenience so we can discuss your needs in this course.
If you have not yet established services through DRS, but have a temporary health condition or permanent disability that requires accommodations (conditions include but not limited to: mental health, attention-related, learning, vision, hearing, physical or health impacts), you are welcome to contact DRS. DRS offers resources and coordinates reasonable accommodations for students with disabilities and/or temporary health conditions.
Reasonable accommodations are established through an interactive process between you, your lecturer(s) and DRS. It is the policy and practice of the University of Washington to create inclusive and accessible learning environments consistent with federal and state law.
Washington state law requires that UW develop a policy for accommodation of student absences or significant hardship due to reasons of faith or conscience, or for organized religious activities. The UW’s policy, including more information about how to request an accommodation, is available at Religious Accommodations Policy. Accommodations must be requested within the first two weeks of this course using the Religious Accommodations Request form.
Most of this course will be run on EdStem - this includes readings, notes, exercises, and assignments. You can develop your programs in EdStem itself (online), or set up an environment to work directly on your device.
For more details, visit the software setup page.
There is no required textbook for CSE 121. All of our readings are available for free on Ed. If you would like a textbook as an additonal resource, we recommend Building Java Programs by Reges and Stepp (5th Edition).
Note that while this is an excellent textbook and includes all topics covered in CSE 121, some topics may appear in a different order than we cover in class. We will put references to relevant chapters of the book on the course website for students who are interested in seeing another perspective on these concepts. The 3rd and 4th editions of the textbook are also reasonable if you already own them or can acquire them more easily. We are not aware of a digital version of the textbook.
To best support your learning in CSE 121 this quarter, we will be using a hybrid classroom model. This will mean our class time will be a mix of time for lecture and time for students to collaboratively work on activities. Time in class spent on students actively participating in their learning has been shown numerous times to improve learning outcomes for students. (Email the instructors if you’re interested in reading about these studies.)
To ensure there is time in class for these opportunities for active practice, we will also ask you to prepare to come to class each day by completing a pre-class reading each day of class. The readings will have a mix of reading slides (often complemented by a video) and questions to let you practice the material you read. The readings/exercises should take about 30 minutes and should be completed before class for that day. The class sessions will begin where the pre-class reading left off after a brief review of the reading.
In a “traditional classroom” model you go to a classroom and a teacher will lecture at you until the end of the session, and then you go home and do the hard work of actually trying to apply that material on practice problems or an assignment. Here are two things that are likely true about “traditional classroom” model:
Notice this list does not contain “effective for student learning”. Unfortunately for the “traditional classroom” model, most evidence has shown that it’s quite ineffective of achieving that goal!
Think of learning programming (or any skill for that matter) like learning how to ride a bike. How many people know how to ride a bike? Quite a few. How many of them do you think learned how to ride a bike by going to a lecture hall two times a week and then a quiz section twice a week listening to someone explain how to ride a bike? Probably no one! Because that’s obviously not learning how riding a bike works! To learn how to ride a bike, you have to actually go out there and ride the bike!
In more general terms, this means learning some concept or some skill requires active participation in the learning process from the students, most commonly accomplished by deliberate practice and learning by doing. Sitting passively in a lecture listening to someone talk fails at accomplishing this fundamental aspect of learning.
The hybrid classroom model is built around fostering an environment for effective practice. Instead of coming to lecture to hear Matt talk about some idea and then trying to go practice the idea at home (a much harder task), we try to flip that model around. You will read and watch videos about the concept first (at your own pace) and then come to our class session to work with your classmates, the TAs, and Matt on practicing that skill. This has the added benefit of collaborative learning where you can work with your peers to construct a working knowledge of the things you saw from the lesson earlier.
It’s okay if the readings don’t make perfect sense the first time you read them! Learning is a process that takes time and work, and revisiting a topic is very important. Things you find confusing in the reading are great things to start off asking questions about on the course message board, in class, or in quiz sections.
Class sessions will be hosted in person. A “normal” day of class will be composed of some recap of the lesson you read before class and alternating time for group work and discussing applications of those concepts as a whole class. The class sessions will be recorded so students who cannot attend can view them later. We do not take attendance, but expect students to be attending to participate in in-class activities, or watching the recordings in the off-chance they can’t attend class.
If you are sick, you should not attend lecture.
Quiz sections are smaller, TA-run sessions where students work in groups on practice problems and review concepts from the previous day’s class session.
Quiz sections meet on Tuesdays/Thursdays according to the time you registered for. Whenever possible, please attend your assigned quiz section. However, if you need to attend a different quiz section on occasion, please reach out to the TA whose section you are visiting ahead of time to request permission.
Quiz sections will not be recorded. Instead, the course staff will post all materials used in section on the course website and will also occasionally post helpful videos covering some of the topics covered in section that day. So, anything missed by not being able to attend in person, you will be able to find asynchronously on the course website.
If you are sick, you should not attend quiz section.
There will be six types of course work assigned in CSE 121:
Short assignments consisting of readings, tutorials, and practice problems for new concepts that will be discussed in the corresponding lesson. Generally, these assignments will be your first introduction to a concept, and we will expect that you have completed at least the reading prior to class. Note that, while we will not explicitly review the topics covered in pre-class work during class, we do not expect you to fully master the material just from these assignments– that will take additional instruction and practice in class.
Pre-class work is not graded, though we will conduct class assuming you have completed the required work for that day.
After (almost) each section, you will submit a form response and/or a small set of problems. These will be assessed on entirely on effort. These will not be a specific portion of your grade; however, they will be an important way to review and summarize your learning from that day and help you identify any areas where you need additional work.
Students who make at least 12 (out of 16 total) submissions will be granted an extra resubmission.
Medium to large assignments in which you will practice your programming skills. Creative projects will usually include a basic set of instructions to get you started followed by open-ended guidelines for extending, expanding, or modifying your work in a manner of your choosing. These assignments are intended to allow you to explore and discover both the programming skills being practiced and your own interests within the world of computer science.
Longer programming assignments that will assess your proficiency with the skills and concepts covered in class. While programming assignments will typically emphasize content introduced shortly before their release, they will often integrate content from earlier in the course as well. Programming assignments will be more structured and have more specific requirements than creative projects, but will still often include smaller open-ended components.
Collections of short, independent problems completed in section on the assigned day. Quiz problems will take a variety of forms, and will assess course learning objectives. Each quiz will generally focus on content introduced since the last quiz, but may include any content previously covered. Quizzes will be taken during your quiz section on a device and will be timed for 45 minutes. Each quiz’s content will be randomly generated from an equivalent set of problems so there is no benefit to taking a quiz later in the day than someone else. Quizzes will be considered open note and open internet, but you should complete all quiz problems individually without communicating with others or misusing tools (and in particular, the academic honesty policy still applies). You will need to bring a laptop or other computing device to section on quiz days – please contact the course staff immediately if that will not be possible to make alternate arrangements.
Similar to quizzes, but with more problems and assessing all content from the course. Unlike quizzes, the final exam will be conducted on paper. Additional details on exam logistics will be posted closer to the end of the quarter.
The final exam will be held on Tuesday, March 18th from 12:30-2:20 PM in KNE 130.
Please reach out to Matt as soon as possible if you cannot take the final exam in-person on the assigned date!
Learning from mistakes is an important part of mastering any skill, especially for novices. To enable this, you are allowed to revise and resubmit your work on programming assignments and creative projects to demonstrate improved mastery after your initial submission, and these grades will fully replace the previous grades.
See Resubmissions for details and rules.
In CSE 121, we do not generally accept late work. If you are unable to turn in an assignment by its initial submission deadline, you will be able to use one of the weekly resubmissions in future weeks to turn in the assignment.
There are 8 assignments and 8 resubmission opportunities. Using a resubmission to turn in an assignment you missed earlier means you will be able to make fewer resubmissions.
You should turn in as much of your work as possible before the initial submission date, so you can get feedback on that and iterate on it in a future resubmission, rather than using that resubmission to get your first piece of feedback on that assignment.
Quizzes must be completed during the scheduled times (usually in your regular quiz section). If you are unable to attend section on a quiz day due to extenuating circumstances (see below) please reach out to Matt immediately.
Please see the policy on Extenuating Circumstances for more information.
Having questions or getting stuck on something is entirely expected in the learning process. If you find something challenging with your studies, that is a sign you are learning! Learning is not something that you need to do alone though! In fact, connecting with your peers or asking a member of the course staff for help can add extreme depth to your knowledge.
Outside of lecture and quiz section, there are three resources in this class specifically designed to answer your questions:
Note: a common misconception is that you can only go to office hours with specific homework questions. That is not true! If you have any questions about course concepts (e.g. from class that day), you are super encouraged to go work on that concept with a member of the course staff at office hours! Getting help with a concept earlier, when you first are feeling unsure, is much better than saving it until you need it on the homework.
For more information, we encourage you to check out the getting help page of the course website.
Work in CSE 121 will be graded using the following scale:
Grade | Description |
---|---|
E Excellent | Evidence of meeting or exceeding all learning objectives is present. Work has only trivial or inconsequential flaws, if any. Little to no room left to improve understanding. |
S Satisfactory | Evidence of meeting most or all learning objectives is present. Work includes minor errors or inconsistencies, but no significant shortcomings. Understanding could potentially be improved, but demonstrated proficiency is acceptable. |
N Not yet | Evidence of meeting some learning objectives is present, but there are significant gaps and/or evidence of not yet meeting other learning objectives. Demonstrated understanding needs further development to meet expectations. |
It is important to note that, under this system, it is the work that is assessed as a proxy for the student. This is an imperfect system, but is necessary to manage a course of the size and scale of CSE 121. It is in your best interest to ensure that your work accurately reflects your proficiency by being careful and diligent in following instructions, meeting deadlines, and understanding requirements.
Pre-class and post-section work is not assigned an ESN grade.
Notation
S+ indicates S or E.
Course grades will be computed as follows:
Minimum requirements for each grade are below. Note that all requirements for a particular grade must be met to guarantee that minimum, though failing to do so does not mean that grade cannot be earned.
Minimum Grade | Requirements |
---|---|
Total ESN available | 33 |
3.5 | 27 Es and 3 additional S+ |
3.0 | 22 Es and 5 additional S+ |
2.5 | 17 Es and 7 additional S+ |
2.0 | 21 S+ |
1.5 | 14 S+ |
0.7 | 8 S+ |
To be guaranteed a particular minimum grade, all requirements for that grade must be met. Failing to meet any of the requirements for a particular minimum grade does not preclude the possibility of receiving that grade, but does mean that grade cannot be guaranteed. Estimates of students’ final grades beyond the requirements listed above will not be provided before final grades are released.
We encourage you to use the minimum grade calculator to see how your scores will map to a minimum promised course grade.
This policy applies to all graded work; that is:
Unless otherwise specified, all graded work must be completed individually, and AI tools (such as ChatGPT, CoPilot, Gemini, etc.) should not be used on graded work in any way.
In particular, all graded work must abide by these rules:
All potential violations of this policy will be reported to the office of Community Standards & Student Conduct for formal investigation. Students found responsible for violations will receive no credit for the assignment(s) on which the policy was violated, and will lose the ability to resubmit that assignment.
When you or a friend needs help on graded work, here are some ways you can collaborate that are most likely not in violation of our policies: