ECE 551: Programming, Data Structures, and Algorithms in C++

FFThis class is aimed at MS/MEng students who want to focus on Computer Engineering, but whose undergraduate degree is in an area other than Computer Engineernig. This course will bring students up to speed on programming, data structures, and algorithms. C++ is the language of choice in this class because C and C++ are very commonly used by Computer Engineers.

Background, Preparation, and Difficulty

This class requires no previous background in programming, as we start from the beginning, however, students without any prior programming experience must work quite hard to keep up with the rapid pace of the class.    Some students think they have had prior experience as they have had courses which focused on memorizing syntax and library functions.  Such students quickly find that this style of background does little to prepare them for serious programming.  

Students who have some background in programming are strongly advised to focus deeply and carefully on the material from the start.  These fundementals form the foundation for more complex material later on, and thus are critical to success in more advanced content. Students who have matery of the first month's worth of material (Chapters 1-13) should take ECE 751 instead.

The pace of this course is quite aggressive: we cover more material in one semester than most undergraduate curriculums do in two semesters.  This pace is required for all Masters students to be "up to speed" for programming in the Spring semester, regardless of the background they came in with.  Accordingly, the workload is high, but not impossible.  Many students have become proficient programmers, even with no prior background.   However, such success requires hard work, discipline, and focus. 

For students who are concerned about their lack of background, and wish to gain some familiarity with programming prior to taking this course, we have a 4 course Coursera specialization which covers the first month of material in this course.  The courses are

  1. Programming Fundementals
  2. Writing, Running, and Fixing Code in C
  3. Pointers, Arrays, and Recursion 
  4. Interacting with the System and Managing Memory

We expect to have an honors section of 551 starting Fall 2019 which will start after the material in this specialization.  If you take these and master this material, the honors section is likely appropriate for you.  

We also have a Coursera specialization in Java for those who are interested in learning that. 

Flipped Classroom and Mastery Learning

In this course, we use a flipped classroom approach: students read All of Programming and watch the videos in it outside of class.  During classtime, students ask the instructor questions, and work on programming assignments.  Working on programming assignments in class ensures that help is readily available, as the instructor is on hand to answer questions immediately.   The expectation is that students will not be stuck for long due to this rapid availability of help.  

The assignments in this class follow a "mastery learning" model, meaning that a student must demonstrate mastery of one assignment by scoring sufficiently highly before the student may start on the next assignment.   Students are allowed to resubmit their assignment multiple times, fixing their mistakes, and learning from them each time.

Resources.

Reading Schedule 

Day Of WeekDateRequiredOptional
Monday8/26Appendices A; B.1–B.5, B.12; C.1–C.3 
Wednesday8/28Chapter 1; Appx C.4–C.7 
Friday8/30Chapter 2; Appx D.4Appx E.1
Monday9/2Chapter 3Appx E.2
Wednesday9/4Chapter 4; Appx B.6–B.8 
Friday9/6Chapter 5; Appx C.8–C.10; D.1Appx C.11–C.12; E.3
Monday9/9Chapter 6; Appx B.9–B.11; D.2 
Wednesday9/11Chapter 7 
Friday9/13Chapter 8 
Monday9/16Chapter 9; Appx D.3.1–D.3.3 
Wednesday9/18Chapter 10 
Monday9/23Chapter 11 
Wednesday9/25Chapter 12; Appx D.3.4–D.3.6, D.5 
Monday9/30Chapter 13 
Wednesday10/2  
Friday10/4Midterm Exam
Monday10/7Fall Break
Wednesday10/9Chapter 14Appx E.6.1
Monday10/14Chapter 15Appx E.6.4–E.6.5
Wednesday10/16Chapter 16 
Monday10/21Chapter 17Appx E.6.3, E.6.6–E.6.7, 6.11
Wednesday10/23Chapter 18Appx E.4, E.6.8
Friday10/25Chapter 20 
Monday10/28Chapter 19 Appx E.6.2, E.6.9
Wednesday10/30Chapter 21 
Monday11/4Chapter 22 
Wednesday11/6  
Monday11/11Chapter 23 
Wednesday11/13Chapter 24 
Monday11/18Chapters 25 and 26 
Wednesday11/20Chapter 27 
Friday11/22Chapter 28 
Monday11/25Chapter 29 
Wednesday11/27Thanksgiving Break
Monday12/2Chapters 30 and 34 Chapters 31, 32, and 33