Syllabus - Computer Science 314 -
Data Structures (Computer Programming 2)
The University of Texas at Austin · Spring 2018
Course web page: www.cs.utexas.edu/~scottm/cs314
Course Objectives: This is a second course in computer programming. The purpose of the course is to learn how to use and implement canonical data structures such as lists, iterators, stacks, queues, priority queues, trees, binary search trees, balanced binary search trees, sets, maps, hash tables, heaps, and graphs. The course also covers testing, reasoning about programs (pre/post conditions, assertions), debugging, abstraction of data, basic algorithm analysis, recursion, canonical sorting and searching algorithms, an introduction to the object oriented concepts of encapsulation, inheritance, and polymorphism, and dynamic programming. Students will be able to implement medium sized programs using the concepts listed. The course is taught using Java.
Quantitative Reasoning Flag: This course carries the Quantitative Reasoning flag. Quantitative Reasoning courses are designed to equip you with skills that are necessary for understanding the types of quantitative arguments you will regularly encounter in your adult and professional life. You should therefore expect a substantial portion of your grade to come from your use of quantitative skills to analyze real-world problems.
This is not an easy course. Based on the historical GPA and drop rate about 30% of the students who attempt this course do not complete it. Succeeding takes a lot of hard work. Here are some tips for success in the course.
Formal Course Prerequisite: CS312 with a grade of C- or higher
Informal Course Prerequisites: Mastery of the following basic programming topics: data types, variables, expressions and operators, control structures (looping and decision making), procedures( a.k.a. functions, methods, or subroutines), parameters, arrays (1d and 2d), simple user defined data types (records, structures, objects), top down design.
You should be able to design and implement a program in Java based on a problem statement. The problem should be complex enough that a well designed solution requires the following:
For example, create from scratch a program that allows two people to play a game of connect 4 on the computer. The display can be a simple text based interface. Both players share the same keyboard and take turns.
Startup: Most of the things you need to do to set up your infrastructure for the class are on the class startup page.
Lecture and Discussion Sections Schedule:
|Unique ID||Lectures||Discussion Section Times and Days||Discussion Section Location||Discussion Section TA|
|51345||MWF 10 - 11 am
|M, 9 - 10 am||GDC 2.410||Aish|
|51350||M, 1 - 2 pm||GDC 2.410||Anthony|
|51355||M, 1 - 2 pm||JES A203A||Shelby|
|51360||M, 2 - 3 pm||PAR 208||Joseph|
|51365||M, 3- 4 pm||PAR 208||Chris|
|51370||MWF 11 am - 12 noon
|M, 10 - 11 am||PAR 208||Ivan|
|51375||M, 10 - 11 am||PAR 304||Dayanny|
|51380||M, 12 noon - 1 pm||GAR 0.128||Hailey|
|51385||M, 3 - 4 pm||BEN 1.126||Lucas|
|51390||M, 3 - 4 pm||GDC 6.202||Jacob|
Conduct in Lecture: I do not allow the use of laptops or any device with a raised screen in class. If you have a device that can lay flat on the desk such as a tablet or 2-1 computer you may use it. I implore you to not use class time to e-mail, update your Facebook page, post to Instagram, etc. If you are addicted to the your smartphone, laptop, or tablet, consider this class your social media free zone. Further, I guarantee you that you will not do well in the course if you are simply looking up long enough to type out what’s on the projector screen before you return to see whether somebody ‘liked’ your comment about the Cheerios you had for breakfast. In fact, the empirical research on this topic is clear: people are incapable of learning and retaining information when they are multi-tasking on their computers (and it’s a distraction to the people sitting around you that are trying to learn something).
Students must attend
the discussion section for which they are officially registered.
Look at your class schedule on UT Direct to verify your unique course number.
Instructor, Mike Scott, email:
office: GDC 6.304
Office Hours: Monday and Wednesday, 2 - 4 pm, Friday 8:30 - 9:30 am. If you cannot make these hours email me to request an appointment.
Office hours are held in the 3rd floor public computer lab in the Gates CS complex, GDC 3.302
|Name||Lab Hours T = Tuesday, H = Thursday|
|Aish||M 12 - 1, T 9 - 11|
|Anthony||T 1 - 3, W 4 - 5|
|Chris||T 12 - 1, H 12 - 2|
|Dayanny||M 9 - 10, T 11 - 12, H 4 - 5|
|Hailey||M 4 - 6. W 6 - 7|
|Ivan||H 11 - 12, F 2 - 4|
|Jacob||M 1 - 2, H 2 - 3, F 1 - 2|
|Joseph||M 7 - 8 pm, W 7 - 8 pm, F 12 - 1|
|Lucas||T 3 - 5, H 3 - 4|
|Shelby||T 8 - 9 am, W 12 - 2 pm|
Required:Purchase an iClicker (a remote control device) from the Co-op bookstore or the iClicker website.
Be sure you get the "iClicker'' brand. We are using iClicker+ but the
iClicker2 or original iClicker will work as well. We are using physical
clickers, NOT REEF polling, web, or app version of iClicker.
Recommended data structures book: Building
Java Programs: A Back to Basics Approach (4th Edition),
Publication Date: February 15, 2016 | ISBN-10: 0134322762| ISBN-13:
| Pearson Education / Addison Wesley. (Previous versions of the book are
acceptable, but there may be differences in section numbers for assigned reading
and problem numbers for suggested exercises.)
Textbook homepage is http://www.buildingjavaprograms.com/
Recommended book for recursion: Thinking Recursively with Java by
Eric Roberts, ISBN: 978-0471701460
Class Participation, iClicker
After registering you DO NOT have to sign up for a particular class on the iClicker website.
Class Discussion Tool: We have a discussion group for the class on Piazza.
We use Canvas to:
Email: All students must become familiar with the University's official e-mail student notification policy. It is your responsibility to keep the University informed as to changes in your e-mail address. You are expected to check e-mail on a frequent and regular basis in order to stay current with University-related communications, recognizing that certain communications may be time-critical. It is recommended that e-mail be checked daily. The complete text of this policy and instructions for updating your e-mail address are available at http://tinyurl.com/pm6ej6e which includes instructions on how to update the email address you have on record with UT.
You are responsible for checking your e-mail and the class discussion group on Piazza regularly for class work and announcements.
Software: Required software for programming assignments is described on this web page: http://www.cs.utexas.edu/~scottm/cs307/software.htm
CS Lab Account to Work on CS Department Machines:
Schedule: A schedule of lecture topics, reading assignments, and assignment due dates is available online, via the class web page, www.cs.utexas.edu/~scottm/cs314/schedule.htm. The schedule page contains links to slides for the lectures, assignments, and online readings. Readings are to be completed before class. The schedule is subject to change.
Grading: The class components used to determine your final average are:
|Component Type||Number||Points||Total Points|
|Programming assignments||11||20 each||220|
|iClicker participation in lecture||40||1 each day||40|
|Quizzes in discussion section||9||10 each||90|
|Exam 1, Wednesday 2/21 7 - 9 pm, Location BUR 106||1||170||170|
|Exam 2, Wednesday 4/4, 7 - 9 pm, Location CLA 0.120 (sections
51345, 51350, 51355), JGB 2.324 all other sections
|Final Exam, During the Final Exam Period. Time and Location TBD||1||300||300|
Grade distributions. Based on the roughly 1900 students who have taken CS314 from me:
Guiding Principle - No whining: Feedback and concerns about the course are always welcome; legitimate grading errors that are identified in a timely fashion will certainly be corrected, but whining is counter-productive and will only irritate those who evaluate your work to determine grades. Realize if you ask for a regrade "because it can't hurt to ask" your score may actually go down if we find more errors and problems.
Important Dates for Changing Academic Status and Dropping the Course: Refer to the Registrar's academic calendar for the deadlines for changes in academic status. Highlights are:
See the College of Natural Science Guidelines and Procedures page for more information. (http://cns.utexas.edu/advising/guidelines-procedures)
Help when You’re Struggling, Have a Crisis, or an Emergency
Please, when something bad happens, or when you’re feeling overwhelmed,get help. Don’t endure it on your own. Even talking through the situation often helps. Here are some options:
See me. Come by office hours, or book an appointment (just email me).
computer science advisors.
They’re not just there to help you register; they can really help in many
situations. If they can't, they can point you in a good direction.
Tel: (512) 471-9509 E-mail: email@example.com (Tell them your UT EID.)
Office: GDC 2.720 Hours: Monday–Friday 8:30 am – 4:30 p.m.
Student Emergency Services.
They are here to help you with all kinds of life’s troubles (family, housing,
health, money, stress, etc.) whether it’s a crisis or not.
Tel: (512) 471-5017 E-mail: firstname.lastname@example.org
Office: SSB 4.104 Hours: Monday–Friday 8 am – 5 p.m.
The core values of the University of Texas at Austin are learning, discovery, freedom, leadership, individual opportunity, and responsibility. Each member of the University is expected to uphold these values through integrity, honesty, trust, fairness, and respect toward peers and community.
Academic Honesty: Taken from the CS department Code of Conduct.
"The University and the Department are committed to preserving the reputation of your degree. It means a lot to you. In order to guarantee that every degree means what it says it means, we must enforce a strict policy that guarantees that the work that you turn in is your own and that the grades you receive measure your personal achievements in your classes:
Every piece of work that you turn in with your name on it must be yours and yours alone unless explicitly allowed by an instructor in a particular class. Specifically, unless otherwise authorized by an instructor:
You are responsible for complying with this policy in two ways:
The penalty for academic dishonesty will be a course grade of F and a referral of the case to the Dean of Students. Further penalties, including suspension or expulsion from the university may be imposed by that office.
One final word: This policy is not intended to discourage students from learning from each other, nor is it unmindful of the fact that most significant work in computer science and in the computing industry is done by teams of people working together. But, because of our need to assign individual grades, we are forced to impose an otherwise artificial requirement for individual work. In some classes, it is possible to allow and even encourage collaboration in ways that do not interfere with the instructor's ability to assign grades. In these cases, your instructor will make clear to you exactly what kinds of collaboration are allowed for that class."
For CS314 the policy on collaboration is modified as follows:
If you are repeating the course you may reuse code you completed on your own. You may NOT use code from a program you worked on as part of pair or code that was from a program involved in an academic dishonesty case. You must start from scratch on any and all programs that:
You are encouraged to study for tests together, to discuss methods for solving the assignments, to help each other in using the software, and to discuss methods for debugging code. Essentially if you talk about an assignment with any one else you are okay, but the moment you start looking at someone else's source code or showing someone else your source code you have crossed the line into cheating. You should not ask anyone to give you a copy of their code or, conversely, give your code to another student who asks you for it. Similarly, you should not discuss your algorithmic strategies to such an extent that you and your collaborators end up turning in exactly the same code. Discuss high level approaches together, but do the coding on your own.
Examples of cheating are many and include accessing another student's account, looking at someone else's solution code, copying or downloading someone else's solution code, referring to solutions from previous semesters, having another student walk you through the solution and how to code it, having another student perform significant debugging of your code, having another student write your code for you and / or allowing others to copy of access your solution code. This means you shall not look on the internet for code to solve your problems.
Examples of allowable collaboration include discussions and debate of general concepts and solution strategies and help with syntax errors.
The code you can reuse in this course are:
You shall not make use of code you find from other sources including the world wide web. Materials from the web should only be used for educational purposes. Thus, you can read about linked lists and look at examples of linked list code, but you must not copy any code from the web or be looking at any of this code from the web when writing anything you turn in.
You are also allowed to post short segments of code (2 lines or less) of code that are giving you syntax errors to the class listserv in order to get help on fixing the syntax error.
If you have any doubts about what is allowed, ask the instructor.
Plagiarism detection software will be used on assignments to find students who have copied code from one another.
For more information on Scholastic Honesty and the UT Honor code see see the
University Policy on Scholastic Dishonesty
Religious Holidays: By UT Austin policy, you must notify me via email of your pending absence at least fourteen (14) days prior to the date of observance of a religious holy day. If you must miss a class, an examination, a work assignment, or a project in order to observe a religious holy day, you will be given an opportunity to complete the missed work within a reasonable time after the absence.
Students with Disabilities: Students
with a documented disability may request appropriate academic accommodations
from the Division of Diversity and Community Engagement, Services for Students
with Disabilities, 512-471-6259 (voice) or 1-866-329-3986 (video phone).
• Please request a meeting as soon as possible to discuss any accommodations
• Please notify me as soon as possible if the material being presented in class is not accessible
• Please notify me if any of the physical space is difficult for you
To the CS 314 home page