|Class Time:||Mon/Wed/Fri 1:30pm-2:20pm|
|Office Hours:||Tuesday, 10:00-11:30am
or by appointment
benjamin.kuperman AT oberlin edu
Please include "cs241" in the subject.
|1||Sep 03||Labor Day|
|Sep 05||Introduction and course overview||HW 0|
|Sep 07||Chapter 1 - Quick intro to C
|Sep 12||Last Day to Add/Drop (Sep 13)||Chapter 2 - Types and operators|
|Sep 14||HW 2|
|3||Sep 17||Chapter 3 - Control flow|
|Sep 19||GDB and Valgrind|
|Sep 21||Chapter 3 - conditionals and loops|
|4||Sep 24||Chapter 4 - functions and scope|
|Sep 26||HW 3|
|Sep 28||Chapter 5 - arrays, strings, and pointers|
|6||Oct 08||Chapter 5 - command line arguments|
|Oct 10||Review for midterm #1||HW 4|
|Oct 12||Midterm Exam #1 [topics]|
|7||Oct 15||Chapter 5 - Multi-dimensional arrays|
|Oct 17||Chapter 6 - structures|
|Oct 22||October Break (Oct 20-28)|
|8||Oct 29||Chapter 6 - structures (continued)|
|Nov 02||HW 5|
|9||Nov 05||Last Day for P/NP, CR/NE,
or Withdraw (Nov 06)
|Nov 07||Huffman compression|
|Nov 09||Chapter 7 - Input and Output||HW 6|
|Nov 16||Bitwise operations|
|11||Nov 19||Review for midterm #2|
|Nov 21||Midterm Exam #2 [topics]|
|Nov 23||Thanksgiving Break (Nov 22-25)|
|Nov 30||HW 7|
|14||Dec 10||Instructor and course evaluations||Review for final exam|
|Dec 12||No Class (ACSAC-23)|
|Dec 19||Final Exam (7-9pm King 221) [topics]|
From the Oberlin catalog course description:
This course will consider the C programming language and its relationship to the Unix operating system. It will also introduce the C++ language and focus on differences between the Java and C++ applications. Some Unix system programminig issues will also be included. The course will require a significant amount of programming.
My goals and objectives for students taking this course are as follows:
We'll be using the canonical K&R C textbook for this class.
You might also be interested in the following books as personal references:
I'll try to make a copy of these available in one of the labs for your use.
There are a number of tools that may be useful to you.
Both of these can be incorporated into Vim or Emacs.
Grades will be calculated based on the following distribution:
The distribution might be adjusted based on the progression of the course.
Regular class attendance and participation is expected. Please talk to me if regular class attendance is going to be a problem.
There will be a number of assignments made in this class. I expect every student to attempt each assignment and turn in the results. You are encouraged to complete every assignment as this is one of the most effective ways to learn the material.
If you know that for some reason you will not be able to submit the assignment before the deadline, you should contact me in advance of the deadline. Extensions are only granted in exceptional circumstances, but need to be done in advance.
Late assignments will be penalized according to the following chart. Extra credit will not be accepted after the initial deadline.
If you have a disability that might impact your performance in this course, or requires special accommodation, please contact me as soon as possible so that appropriate arrangements can be made. Support is available through Student Academic Services, specifically Jane Boomer. You will need to contact them to get your disability documented before accommodations can be made.
I have very low tolerance for academic dishonesty, and will vigorously pursue available remedies for any incidents. All work in this class is to be performed according to the Oberlin Honor Code. Specifically I expect that:
All assignments must include the following signed statement:
"I affirm that I have adhered to the Honor Code in this assignment."
Electronic submissions should include the honor statement in either the README file or header comments and must include your name.
Contact me if you are interested in a Student Academic Services approved tutor.
The CSMC might hold walk-in tutoring sessions as well.