|
CS 112 - Introduction to Computer Science II
Course Information |
Course Overview
In Introduction to Computer Science I, one learns the basic building blocks
for problem-solving using the Java programming language. Introduction
to Computer Science II continues problem-solving development with group work,
deeper coverage of object-oriented programming topics, exception handling,
graphical user interfaces, the Java event model, file I/O, and other advanced
programming topics. We also begin coverage of basic data structures (e.g. collections, linked lists)
and algorithms (e.g. sorting, searching). Thus we
transition to the Data Structures course where one learns a collection of
common, important tools for problem solving that find application in many diverse
problems computer scientists solve.
Learning Objectives
- Refresh and reinforce Computer Science I problem solving skills.
- Grow group work skills through pair programming.
- Experientially learn more advanced programming topics.
- Prepare for future Data Structures study through a final design
project that requires the development of a data structure.
Text
Instructor
Todd Neller
Section A Lecture: MoWeFr 1:10-2:00PM, Glatfelter 112
Section B Lecture: MoWeFr 2:10-3:00PM, Glatfelter 112
Office: Glatfelter 209
Office Hours: Mo 3:10-3:45PM, Tu 1-5PM, We 3:10-5PM, Th 1-3:45PM, Fr 3:10-5 or by appointment. (I finish teaching each day just before office hours, so office hours will start when I arrive back at my office.) Note: Generally, feel free to drop in if my office door is open (i.e., most of the time beyond class).
A Video Explainer about Office Hours for Students
Phone: 337-6643
E-mail:
Student Assistants
In-class:
- Section A: Philip Phong Pham, office hours: Thursday 7-9PM, Glatfelter 207
- Section B: Yashaswe Amatya, office hours: Monday 7-9PM, Glatfelter 207
Grading:
- John Llano, office hours: Tuesday 7-9PM, Glatfelter 207
- Barry Yihui Tang, office hours: Sunday 7-9PM, Glatfelter 207
Grading
45% Assignments
10% Individual Exercises
10% Fourth Hour Project
25% Quizzes & Exams
5% Colloquium Attendance
5% Class Attendance / Participation
You are responsible to know the material
from each lecture and reading assignment before the start of the next class.
Homework is due at the beginning of lecture on the due date. Source code that does not
compile may not receive partial credit. (It need not be free from logic
errors.) You are required to attend 2 colloquia or approved departmental
events over the course of the semester.
Late Assignment Policy
Since graders will look in the submission system for on-time work only, it is
your responsibility to email me and graders (1) expressing your intention to submit late work, and (2) when you have submitted late work. Step (1) alerts us to not grade any work that has been submitted so as to prevent grading of that work. There are no regrades.
Only pair homework assignments (not individual exercises) will be accepted late. Late
homework will receive a flat 10% penalty (e.g. what would have received 95%
would receive 85% credit, not 85.5%). Late homework will only be accepted
until either 9 classes later or half-way between the due date and the last day of classes (rounding down),
whichever comes first: "Last Class for Late Submission" Table
Attendance
Class attendance and participation is required. If you attend all
classes and are willing to participate, you'll get 100% for this part of your
grade. Even if you know enough to give a particular lecture, please consider
the value of helping your peers during in-class exercises.
Woody Allen is quoted as saying
"80% of success is
just showing up." While our class attendance/participation grade
is not 80% of the final grade, it is critical that late arrivals and unexcused
absences are not excessive. Missing more than half of class unexcused is
considered being absent. An unexcused late arrival is counted as a half
absence. If the total number of absences counted this way exceeds
20% of class meetings, i.e. 8.5 absences or more, the student will have failed
the course.
Honor Code
Honesty, Integrity, Honor. These are more important than anything
we will teach in this class. Students can and are encouraged to help
each other understand course concepts, but all graded work must be done
independently unless otherwise specified (e.g. group work). Submitted work
should be created by those submitting it. Submission
of plagiarized code or design work is a violation of the Honor Code, which I
strictly enforce. For
detailed information about the Honor Code, see
https://www.gettysburg.edu/offices/center-student-success/honor-code/.
What is permitted:
- Discussing algorithms, syntax, and problem specifications with other
students
- Seeking assistance (as needed) from CS professors, students assistants,
and approved tutors
- Use of "starter code" supplied by your professor, or code you have
previously developed
What is not permitted:
- Use of generative AI tools, including but not limited to GitHub Copilot, ChatGPT, etc., unless explicitly allowed for a given assignment,
- Sharing code: Verbal dictation of code, transference of code (e.g.
e-mail, file transfer, entry of printed output, etc.). An important
component of this experiential learning process is developing the ability to
independently devise algorithms and express them in program code.
- Viewing and/or using unauthorized code (e.g. solutions found online,
downloads from code repositories, etc.)
- Submitting work that implicitly takes credit for work that should be
credited to others
- Efforts to obscure the source of unauthorized work
- Outsourcing work
Put simply, students may discuss assignments at an abstract level (e.g.
specifications, algorithm pseudocode), but must actually implement solutions
independently or in permitted groups. Credit should be given where credit
is due. Let your conscience be your guide. Do not merely focus on
the result; learn from the process.