CSC1020: Data Structures, I/O, and Graphical Interfaces

This course covers interfaces, exceptions, file input/output, graphical user interfaces and event-driven programming as well as the organization of data and the algorithms that act upon them. Various sorting algorithms and data structures are covered. The topics of arrays, linked lists, stacks, queues, trees, sets, and hash tables are introduced. Fundamentals of algorithm performance are also introduced, with an emphasis placed on time complexity analysis. Laboratory activities include implementation of data structures as well as development of GUI applications that apply data structures from standard libraries. (prereq: CSC1010 or CSC1110 or CSC1110A) (4-2-5)

Outcomes

On successful completion of this course, the student will be able to:

Textbooks

  1. Data Structures Abstraction and Design Using Java 3rd Ed., by Koffman and Wolfgang, Wiley, 2016. ISBN: 978-1-119-23914-7
  2. Optional: Introduction to Programming with Java: A Problem Solving Approach, 3rd Ed., by Dean and Dean, McGraw-Hill, 2021. You likely have this book from CSC1110, but, if not, there are two purchasing options:
    1. VitalSource Inclusive Access eBook with Online Access, ISBN: 978-1-26-095839-3
    2. If you'd like a hard copy, you can also add Loose Leaf Inclusive Access, ISBN: 978-1-26-426033-1

Grading

Labs 20%
Reading Quizzes 5%
Lab Quizzes 5%
Homework 10%
In-Class Exercises/Attendance 5%
Exam I 15%
Exam II 15%
Final Exam 25%
Total 100%