Fall 2017 Course Syllabus
Computer Science 111 - Introduction to Algorithms and Programming/Java
Course Description: This course is an introduction to algorithms, their representation, design, structuring, analysis and optimization. It requires implementation of algorithms as structured programs in a high level language. This course will use Java and students will be expected to write and execute Java programs in the lab section.
When and Where: Tuesdays & Thursdays 2:00 PM - 3:20 PM @ HSLH-133
Please check Canvas each week for:
- Weekly Lecture Notes
- Online Course Work
Instructor: Jason Berry, Office Hours: Tuesdays & Thursdays 5:00 PM - 6:00 PM @ TLC [or by appt.]
Required Text: Introduction to Java Programming, Brief Version 10th Ed., Author: Liang, ISBN: 978-0-13-359220-7
Grading: Grading will be based on the following breakdown:
Quiz 1 10% 20 points
Midterm 20% 40 points
Quiz 2 10% 20 points
Final 30% 60 points
Online Course Work 30% 60 points
Needed Point Totals: A – 175 points, B – 150 points, C – 120 points, D – 100 points
NO, NO, NO Laptops, cell phones or Ipod/MP3 players are to be used during class lectures. Laptops may ONLY be used during lab time. Surfing the Internet during class time is reserved for class related web sites. EBay, chat rooms, sports sites and other non class related surfing is strictly prohibited. Violations of these rules may result in a penalty reduction of points.
See Below for Important Dates
Please be sure to avoid scheduling conflicts with these dates.
Student Learning Outcomes:
Evaluate the basic concepts of computer programming and analyse their impact on algorithms, problem solving and program implementation.
- What is a computer, Binary Representation of Information, Programming Languages, Java, Java Byte Code, Java Virtual Machine, First Java Program Reading Assignment - Chapter 1
- Java Language Elements, Variables and data types, Strings, Syntax and Semantics, Programming Errors, Debugging Reading Assignment - Chapter 2
- Selections (Control Statements), if, if-else, switch, Relational and logic operators, Precedence and Associativity Reading Assignment - Chapter 3
- Loops: while, do-while, for, break and continue Reading Assignment - Chapter 5
- Methods (aka functions, procedures, subroutines), Parameters (pass by value), Scope, Lifetime, Overloading Reading Assignment - Chapter 6
- Arrays, Looping through arrays, search algorithms, Sort algorithms, Array parameters (pass by reference), 2-D and higher arrays Reading Assignment - Chapter 7 (some 8)
- Classes and Objects, Building a class, Using objects, Static variables and methods, Constructors, Reference variables, Visibility modifiers Reading Assignment - Chapter 9
- Strings and File I/O, String classes, Open and read/write text files, Intro to exception handling Reading Assignment - Chapters 4 and 12
- Inheritance, Class hierarchy, Constructors, Private-Protected-Public, Polymorphism Reading Assignment - Chapters 10 and 11
- Abstract classes, Interfaces, Object Oriented Design and Patterns Reading Assignment - Chapter 13
- Java FX, Swing, AWT, Exception Handling, Event Drivien and GUI programming Reading Assignment - Parts of Chapters 12, 14, 15, and 16
- Recursion, recursive algorithms, Complexity analysis, Binary search algorithm Reading Assignment - Chap. 18
The syllabus page shows a table-oriented view of the course schedule, and the basics of course grading. You can add any other comments, notes, or thoughts you have about the course structure, course policies or anything else.
To add some comments, click the "Edit" link at the top.