Welcome to CS21! This course will introduce fundamental ideas in computer science while also teaching you how to write computer programs. We will study algorithms for solving problems and implement solutions in the Python programming language. Python is an interpreted language that is known for its ease of use. We also introduce object-oriented programming and data structures. A deeper coverage of these topics will be presented in CS35.
This course is appropriate for all students who want to learn how to write computer programs and think like computer scientists. It is the usual first course for computer science majors and minors. Students with advanced placement credit or extensive programming experience should place out of this course and instead begin with CS35. If you have no prior computer science or programming experience, this course is designed for you.
By the end of the course, we hope that you will have developed the following skills:
Several student mentors will assist me in class and run study sessions in the main CS lab (Science Center 240) on the following evenings:
Day | Time | Location |
---|---|---|
Sunday | 7:00–9:00pm | Sci Center 240 |
Wednesday | 7:00–9:00pm | Sci Center 240 |
You are invited – and encouraged – to participate in these study sessions to prepare for quizzes, to discuss programming concepts, and to get friendly assistance in working on lab assignments. Our CS mentoring team is dedicated to helping students, who have no prior knowledge of computer science, learn to program in Python while keeping their senses of humor intact. As an added bonus, free food is often provided at the sessions.
Time | Professor | Location |
---|---|---|
Monday 2:30–4:00pm | Danner | Sci Center 240 |
Monday 3:30–5:00pm | Newhall | Sci Center 240 |
Friday 1:00–2:00pm * | Knerr | Sci Center 252 |
* if there's a campus collection, the Friday lab will be 2-3pm
WEEK | DAY | ANNOUNCEMENTS | TOPIC & REFERENCES | INCLASS & ASSIGNMENTS |
1 | Aug 31 | Introduction to Python and Unix Ch. 1-2 (Z), Ch. 1-Ch. 2 (D) |
In class: week 1 Assn: lab 0 Assn: lab 1 |
|
Sep 02 | ||||
Sep 04 | ||||
2 | Sep 07 | Numbers and Strings Ch. 3-4 (Z), Ch. 2 (D) |
In class: week 2 Assn: lab 2 |
|
Sep 09 | Practice Quiz 1 (pdf) | |||
Sep 11 | Drop/Add Ends | |||
3 | Sep 14 | Booleans Ch. 7 and p. 247 (Z), Ch. 5.1-5.7, Ch. 7 (D) |
In class: week 3 Assn: lab 3 |
|
Sep 16 | ||||
Sep 18 | ||||
4 | Sep 21 | Graphics, objects The Graphics Library Ch. 5 Online copy (Z) |
In class: week 4 Assn: lab 4 |
|
Sep 23 | ||||
Sep 25 | Practice Quiz 2 (pdf) | |||
5 | Sep 28 | Functions, objects Ch. 6 (Z), Ch. 3, Ch. 6 (D) |
In class: week 5 Assn: lab 5 |
|
Sep 30 | ||||
Oct 02 | ||||
6 | Oct 05 | Loops, Top Down Design Ch. 8, 9 (Z), Ch. 7 (D) |
In class: week 6 Assn: lab 6 |
|
Oct 07 | Practice Quiz 3 (pdf) | |||
Oct 09 | ||||
Oct 12 |
Fall Break |
|||
Oct 14 |
||||
Oct 16 |
||||
7 | Oct 19 | Top Down Design, File I/O Ch. 9, 4.6 (Z), Ch. 14 (D) |
In class: week 7 Assn: lab 7 |
|
Oct 21 | ||||
Oct 23 | ||||
8 | Oct 26 | Searching, Analysis of Algorithms Ch. 13.1 (Z), Ch. 9 (D) |
In class: week 8 | |
Oct 28 | Practice Quiz 4 (pdf) | |||
Oct 30 | ||||
9 | Nov 02 | Recursion, Sorting Ch. 13.2-13.3 (Z), Ch. 5.8-5.10, 9 (D) |
In class: week 9 Assn: lab 8 |
|
Nov 04 | ||||
Nov 06 | CR/NC/W Deadline | |||
10 | Nov 09 | More Searching, Sorting and Recursion Ch. 13.1-13.3 (Z) |
In class: week 10 Assn: lab 9 |
|
Nov 11 | Practice Quiz 5 (pdf) | |||
Nov 13 | ||||
11 | Nov 16 | Defining new classes Ch. 10 (Z), Ch. 15-17 (D) |
In class: week 11 Assn: lab 10 |
|
Nov 18 | ||||
Nov 20 | ||||
12 | Nov 23 | Linked lists intro handout |
In class: week 12 | |
Nov 25 | ||||
Nov 27 |
Thanksgiving Break |
|||
13 | Nov 30 | Linked lists handout |
In class: week 13 | |
Dec 02 | ||||
Dec 04 | ||||
14 | Dec 07 | Wrapup |
In class: | |
Dec 17 |
Final Exam 7pm Sci 101 |
40% | Lab assignments |
30% | Quizzes |
5% | Class Participation |
25% | Final Exam |
Programming assignments will typically be assigned in class at the beginning of the week and will be due before midnight the following Tuesday night. You are strongly encouraged to start early and to attend the study sessions for extra practice.
You will submit you assignments electronically using the handin21 program. You may submit your assignment multiple times, but each submission overwrites the previous one and only the final submission will be graded. Late assignments will not be accepted except in extreme situations and only if you contact me before the deadline. Even if you do not fully complete an assignment, you may submit what you have done to receive partial credit.
Programming is not a dry mechanical process, but a form of art. Well written code has an aesthetic appeal while poor form can make other programmers and instructors cringe. Programming assignments will be graded based on style and correctness. Good programming practices usually include many of the following principles:
Contact Tracey Rush at the Dean's office and follow these steps for obtaining accommodations.
Academic honesty is required in all work you submit to be graded. You may not submit work done with (or by) someone else. You may not examine or use work done by others to complete your own work. You may discuss assignment specifications and requirements with others in the class to be sure you understand the problem. In addition, you are allowed to work with others to help learn the course material. However, with the exception of the student mentors and your partner on group assignments, you may not work with others on your assignments.
All code you submit must be your own with the following permissible exceptions: code distributed in class, code found in the course text book, and code worked on with an partner. In these cases, you should always include detailed comments that indicates on which parts of the assignment you received help, and what your sources were.
"It is the opinion of the faculty that for an intentional first offense, failure in the course normally is appropriate. Suspension for a semester or deprivation of the degree in that year may also be appropriate when warranted by the seriousness of the offense." - Student Handbook (2009-2010, pg18 Section I.B.3.b.i)
Please see me if there are any questions about what is permissible.
Vi Quick Reference
Python style guide From Prof. Tia Newhall
Using Unix Improved
Basic Unix
Commands
Python Documentation
Zelle Textbook site
How To Think Like a Computer Scientist: Learning with Python