SCMP 118 – Introduction to Programming in C++

Sections 1 (1:10-2:30 TH) and 2 (2:40-4:00 TH)

Instructor: James Skon

Fall 2016

This course presents an introduction to computer programming intended both for those who plan to take further courses in which a strong background in computation is desirable and for those who are interested in learning basic programming principles. The course will expose the student to a variety of applications where an algorithmic approach is natural and will include both numerical and non-numerical computation. The principles of program structure and style will be emphasized. Offered every semester.

Course Information

  • James Skon
  • Office Hayes Hall 303
  • Office Hours: MTWHF 10:00-11:00
  • Phone: (740) 427-5369
  • Textbook: Problem Solving with C++ 8th ed, by Walter Savitch.
  • Room and Time: PRCL09, 1:10-2:30, 2:40-4:00 Tuesday and Thursday
  • Paperless: This course is intentionally paperless. All assignments are turned in online through Moodle. The instructor will normally not accept work written or printed on paper. (Any excepts must be pre-approved by the instructor).

Tutor

  • Ghada Bakbouk
  • Email: bakboukg@kenyon.edu
  • Tutoring Sessions in Pierce PRCL09
    • Sunday 7:00-8:30pm
    • Thursday 7:00-8:30pm

Resources

Code Lab

CodeLab is a tool that develops coding skills and understanding through coding exercises. The best way to learn to program is to program! Just like the best way to learn to play a sport is to play that sport. CodeLab assignments are NOT accepted late.

Assignments

Due Date: All assignments are due by midnight the day of due unless otherwise specified. There will be a 12 hour grace period during which the student will received a penalty equal to 5% of the value of the assignment; any assignments submitted more than 12 hours late will not be accepted. Exception: Each student may have a 24 hour extension on one lab and one history without penalty. This extension will be applied to the first assignment submitted outside the grace period (or retroactively used to cancel one grace-period penalty if not used by the end of the semester.)

Missing Lab Assignments: Labs are an important part of this class; the effort spent on them is a crucial part of the learning process. Failure to submit labs is unacceptable: students earning 0s on two assignments cannot receive a grade higher than a B- for the course; students earning three 0s will receive an automatic F for the course.

Collaboration: In order to facilitate learning, students are encouraged to discuss assignments amongst themselves. Copying a solution is not, however, the same as “discussing.” A good rule of thumb is the “cup of coffee” rule. After discussing a problem, you should not take away any written record or notes of the discussion. Go have a cup of coffee or cocoa, and read the front page of the newspaper. If you can still re-create the problem solution afterward from memory, then you have learned something, and are not simply copying. (The “group problems” are exempt from this, as they are intended to be done together.)

Computer History Assignments: Once a week you will turn in a brief essay on some computer history fact from the Computer History Museum (or other computer history source). One or two people people will be chosen each week to oraly describe what they found in 2 minutes at the beginning of class. I will ask for volunteers, but will cycle through everyone before I repeat anyone. The idea is give to us all an opportunity to explore the history of computer science, and to find something that interests each of us. Start by going to the computer history timeline, and for each assignment explore the requested years until you find something interesting. Then write up a 200-300 word essay about what you found, what you found compelling, and why you think it is significant. Write the essay in Moodle, and include a link to the item you found so it can be displayed while you share in class. These are due midnight before the day they will be presented (and appear in the calendar below). Late submissions will not be accepted on these assignments.

Course Grades

Category%Notes
History Essays5%Equally distributed
Labs45%Equally distributed
Quizzes10%Equally distributed
Code Lab15%All questions equal weight
Exams25%Midterm 10%, Final 15%

Course Calendar

May be subject to change as course unfolds. Asways check here for latest update.

DateRequired ReadingNotes/LinksCode SamplesQuizSlidesCodeLabAssignment Due
Aug 25Chapter 1 – Introduction to Computers and C++ Programming. Our Computing EnvironmentTutorNotes1CodeDay1 Ch1.ppt  
Aug 30Chapter 1.3-1.4 and C++ Programming. Our Computing Environment. Trying C++, using CodeLabNotes2
Netbeans First Program
CodeDay2 Day2.pptx  
Aug 30Evening (7:00) in Hayes 311. Help installing Netbeans on your Laptop.      
Sept 1Chapter 2.1-2.2 – C++ Basics (Variables, Assignments, I/O)Notes3CodeDay3Linkch2-2.1-2.pptxFirst ExercisesLab 0 Chapter 1
Sept 3Sunday Evening Tutor Session
Hayes 311 7:00-8:30
      
Sept 6Chapter 2.2-2.5 – Data Types, Expressions, Flow Control, StyleNotes4CodeDay4Linkch2.3-5.pptAssignment,
Input And Output,
Integers,
Other Expressions,
Techniques1
1930s
Sept 8Chapter 3.1-3.3 – Boolean Expressions, Branches, LoopsNotes5CodeDay5Linkch2.3-5.ppt
ch_03-1.ppt
 Lab 1-1 Chapter 2
Sept 13Chapter 3.3-3.4 – More on LoopsNotes5CodeDay5Linkch_03.pptOther Expressions,
Techniques1, Conditionals, Loops, Constants
Lab 1-2 Chapter 2
Sept 15Chapter 3.3-3.4 – More on LoopsNotesCode 
ch_03-Part3.ppt
 1940-1944
Sept 20Chapter 4.1-4.2 – Introduction to FunctionsFunctionsCode1 Code2Linkch4.1-3.ppt
ch_04.4-6.ppt
  
Sept 22Chapter 4.3-4.6 – Procedural Abstration, Local Variables, and Overloading Names.Functions2CodeLinkCH_5.1-3.pptFunctions,
Type casting, Boolean Expressions, Multiway If-Else, Switch, Iteration
1945-1949Lab 2 Chapter 3
Sept 27Chapter 5.1-5.3 – void Functions, Call-By-Referance, Procedural AbstrationCreating random numbersCodelinkCH_5.4.pptVoid functions, Call-By-Referance1950-1954
Sept 29Chapter 5.3-5.5 – Procedural Abstration, debugging   CH_5.4.ppt Lab 3 Chapter 4
Oct 4Chapter 7.1-7.3 – Arrays, Arrays with Functions CodelinkCh7.1-4.ppt Lab 4-1 Chapter 5
Oct 6No class, October Break      
Oct 11Chapter 7.1-7.3 – Arrays, Arrays with Functions Code  ArraysLab 4-2 Chapter 5
Oct 13Midterm Exam      
Oct 18  Code  Array TechiquesLab 5 Chapter 7 1955-1959
Oct 20Chapter 7.3-7.4 – Programming with Arrays, sorting, Multidimensional ArraysStringNotes1Code Ch7.1-4.ppt  
Oct 25Multidimensional Arrays – Tick Tack Toe
Chapter 8.1, 8.2 – C-Strings and String class
 Code Ch7.4.ppt
Ch8.1-2.ppt
 1960-1964
Lab 6 Chapter 7
Oct 27Chapter 8.2 – String class Code   1965-1969
Nov 1Chapter 8.3,10.1 VectorsStructNotes C++ string referenceCode Ch8-3.pptStrings 
Nov 3Chapter 10.2 – Intro to Object Oriented Concepts, structuresClassNotes1CodeLinkIntroObjectsc.ppt Lab 7 Chapter 7
1970-1974
Nov 8Chapter 10.2, 10.3, Classes, CodeLinkCh_10_2-3.ppt 1975-1979
Nov 10Chapter 10.3, 6.1, 6.2 – ADT’s, File I/O CodeLinkCh_06.1-3.ppt Lab 8 Chapter 8
Nov 15Chapter 6.2, 6.3 – Character I/O, Array’s with ClassesClasses Tutorial  Ch_06.1-3.ppt 1980-1984
Nov 17Chapter 11.1,11.2,11.3 – Friend Functions, OverloadingShakespeare in class start activityCodeLinkch_11.ppt Lab 9 Chapter 10
Nov 22-24No Class, Thanksgiving Break    Class Definitions 
Nov 29Chapter 11.2, 11.3 – Arrays and Classes, Dynamic Arrays Code ch_11.ppt 1985-1989Extra Credit Tick Tack Toe
Dec 1Chapter 12.1 Friend Functions, Overloading, inheritanceIn Class ActivityCodeLinkch_12.ppt 1990-1994
Dec 6Chapter 14.1, 14.2 – Recursion, The Binary Search AlgorithmFactorialBinary SeachBinary/Linear CompareSortingMerge SortCodeMerge SortLinkch14.ppt 1995-1999
Dec 8Towers of Hanoi – Example,ProgramCode ch14.pptRecursion2000-2010
Dec 12Final Exam Section 1: Final Project Demos
Monday, December 12 at 6:30 p.m.
Section 1: Demo Time Signup    Final Project
Dec 14Final Exam Section 2Final Project Demos
Wednesday, December 14 at 8:30 a.m.
Section 2: Demo Time Signup     

Assignments are due by midnight of the day due.

Academic Honesty

Any work you submit for credit in this course must result directly from your own understanding. Moreover, written work must be a creation of your own hand. Presenting the work of others as your own is strictly prohibited. At Kenyon we expect all students, at all times, to submit work that represents standards of academic integrity. It is the responsibility of each student to learn and practice the proper ways of documenting and acknowledging those whose ideas and words you have drawn upon (see Academic Honesty and Questions of Plagiarism in the Course Catalog). Ignorance and carelessness are not excuses for academic dishonesty. If you are uncertain about the expectations for academic honesty in this class, please ask for clarification.

It is likely that proof, algorithm and code solutions for most problems exist online. Generally you should not search for any of these solutions. If you do use online or written documents, you must fully disclose and reference everything used, and be prepared to lose some credit if the help is deemed to be beyond that which you should used. The rule of thump is you can use references to help understand the problems and terminology, but should not use (and copy or modify) complete or partial solutions found online.

If you use online resources, up to and including the use of code found on the internet, and do not disclose it, you will be subject to AIB notification.

Disabilities

If you have any disability and therefore may have need for some type of accommodation in order to participate fully in this class, please feel free to discuss your concerns in private with Erin Salva, Coordinator of Disability Services (phone 5145).

Statement on Title XI
Kenyon College seeks to provide an environment that is free of gender bias, discrimination, andharassment. If you have been the victim of sexual harassment/misconduct/assault,
interpersonal violence, or stalking we encourage you to report this. If you report this to a faculty member, she or he must notify Kenyon’s Title IX coordinator of any information about the incident that you provide. Kenyon College’s Title IX and VAWA Policy is available at: http://www.kenyon.edu/directories/offices-services/title-ix/policy/

Scroll to Top