CQUniversity Unit Profile
COIT20256 Data Structures and Algorithms
Data Structures and Algorithms
All details in this unit profile for COIT20256 have been officially approved by CQUniversity and represent a learning partnership between the University and you (our student).
The information will not be changed unless absolutely necessary and any change will be clearly indicated by an approved correction included in the profile.
General Information

Overview

This unit is designed for students who want to study advanced data structures and algorithms for software development using an object oriented programming language. Students will learn to evaluate the use of data structures and algorithms to construct solutions to information technology problems. Topics covered include: classes, inheritance, polymorphism, exceptions, graphical user interfaces, database programming, recursion, linked lists, stacks, queues, priority queues, trees, search trees, graphs, sorting and searching algorithms. The object-oriented design will also be covered. Note: If you have completed unit COIT23001 then you cannot take this unit.

Details

Career Level: Postgraduate
Unit Level: Level 9
Credit Points: 6
Student Contribution Band: 8
Fraction of Full-Time Student Load: 0.125

Pre-requisites or Co-requisites

Pre-requisite: COIT20245 Introduction to Programming

Important note: Students enrolled in a subsequent unit who failed their pre-requisite unit, should drop the subsequent unit before the census date or within 10 working days of Fail grade notification. Students who do not drop the unit in this timeframe cannot later drop the unit without academic and financial liability. See details in the Assessment Policy and Procedure (Higher Education Coursework).

Offerings For Term 1 - 2017

Brisbane
Distance
Melbourne
Rockhampton
Sydney

Attendance Requirements

All on-campus students are expected to attend scheduled classes – in some units, these classes are identified as a mandatory (pass/fail) component and attendance is compulsory. International students, on a student visa, must maintain a full time study load and meet both attendance and academic progress requirements in each study period (satisfactory attendance for International students is defined as maintaining at least an 80% attendance record).

Class and Assessment Overview

Recommended Student Time Commitment

Each 6-credit Postgraduate unit at CQUniversity requires an overall time commitment of an average of 12.5 hours of study per week, making a total of 150 hours for the unit.

Class Timetable

Bundaberg, Cairns, Emerald, Gladstone, Mackay, Rockhampton, Townsville
Adelaide, Brisbane, Melbourne, Perth, Sydney

Assessment Overview

1. Practical and Written Assessment
Weighting: 15%
2. Practical and Written Assessment
Weighting: 30%
3. Examination
Weighting: 55%

Assessment Grading

This is a graded unit: your overall grade will be calculated from the marks or grades for each assessment task, based on the relative weightings shown in the table above. You must obtain an overall mark for the unit of at least 50%, or an overall grade of ‘pass’ in order to pass the unit. If any ‘pass/fail’ tasks are shown in the table above they must also be completed successfully (‘pass’ grade). You must also meet any minimum mark requirements specified for a particular assessment task, as detailed in the ‘assessment task’ section (note that in some instances, the minimum mark for a task may be greater than 50%). Consult the University’s Grades and Results Policy for more details of interim results and final grades.

Previous Student Feedback

Feedback, Recommendations and Responses

Every unit is reviewed for enhancement each year. At the most recent review, the following staff and student feedback items were identified and recommendations were made.

Feedback from Moodle Course evaluation

Feedback

One suggestion feedback is to have JQuery and JSF as part of the course. These are already covered in other courses. A number of suggestions are on improved clarity of the Assignment.

Recommendation

The Assignment specification can be made clearer with no major changes. The formal review will also help to achieve this.

Action

Assignment specification is peer reviewed.

Unit Learning Outcomes
On successful completion of this unit, you will be able to:
  1. Compare and contrast different algorithms in problem solving.
  2. Choose and compare appropriate data structures in program design.
  3. Evaluate a variety of data structures and algorithmic approaches including: recursion, linked lists, stacks, queues, trees, graphs, sorting and searching.
  4. Analyse, develop and implement software solutions with the focus of data structures and algorithms.
  5. Apply classes, inheritance, polymorphism and exception handling in the context of data structures and algorithms.
  6. Programmatically connect to a database and implement the database operations.

Australian Computer Society (ACS) recognises the Skills Framework for the Information Age (SFIA). SFIA is in use in over 100 countries and provides a widely used and consistent definition of ICT skills. SFIA is increasingly being used when developing job descriptions and role profiles.
ACS members can use the tool MySFIA to build a skills profile at https://www.acs.org.au/professionalrecognition/mysfia-b2c.html
This unit contributes to the following workplace skills as defined by SFIA. The SFIA code is included:
  • Systems design (DESN)
  • System Integration (SINT)
  • Program ming/Software Development (PROG)
  • Data Analysis (DTAN)
  • Database/Repository Design (DBDS)
  • Testing (TEST)
  • Applications Support (ASUP)

Alignment of Learning Outcomes, Assessment and Graduate Attributes
N/A Level
Introductory Level
Intermediate Level
Graduate Level
Professional Level
Advanced Level

Alignment of Assessment Tasks to Learning Outcomes

Assessment Tasks Learning Outcomes
1 2 3 4 5 6
1 - Practical and Written Assessment - 15%
2 - Practical and Written Assessment - 30%
3 - Examination - 55%

Alignment of Graduate Attributes to Learning Outcomes

Graduate Attributes Learning Outcomes
1 2 3 4 5 6
1 - Knowledge
2 - Communication
3 - Cognitive, technical and creative skills
4 - Research
5 - Self-management
6 - Ethical and Professional Responsibility
7 - Leadership
8 - Aboriginal and Torres Strait Islander Cultures

Alignment of Assessment Tasks to Graduate Attributes

Assessment Tasks Graduate Attributes
1 2 3 4 5 6 7 8
1 - Practical and Written Assessment - 15%
2 - Practical and Written Assessment - 30%
3 - Examination - 55%
Textbooks and Resources

Textbooks

Prescribed

Java How to Program : Early Objects Edition

Edition: 10 (2014)
Authors: Paul Deiteil & Harvey Deitel
Pearson
Upper Saddle River Upper Saddle River , NJ , USA
ISBN: 9781292018195
Binding: Paperback

Additional Textbook Information

This unit has an open book final examination where students can take their Textbook with them to the examination. Therefore, it may be better to buy a hard copy of the Textbook even though rest of the study can be managed with an e-Book. Students can take a copy of consolidated notes to refer in the examination. So it is not mandatory to buy a Textbook.

IT Resources

You will need access to the following IT resources:
  • CQUniversity Student Email
  • Internet
  • Unit Website (Moodle)
  • Java Development Kit (JDK) 1.8 or later
  • MySQL Database Server 5.7 or later
  • NetBeans IDE
  • Textpad editor
Referencing Style

All submissions for this unit must use the referencing style: Harvard (author-date)

For further information, see the Assessment Tasks.

Teaching Contacts
Mary Tom Unit Coordinator
m.tom@cqu.edu.au
Schedule
Week 1 Begin Date: 06 Mar 2017

Module/Topic

A Deeper Look at Classes and Objects

Chapter

Chapters 8

Events and Submissions/Topic

Week 2 Begin Date: 13 Mar 2017

Module/Topic

Object Oriented Programming: Inheritance

Chapter

Chapter 9

Events and Submissions/Topic

Week 3 Begin Date: 20 Mar 2017

Module/Topic

Object Oriented Programming: Polymorphism and Interfaces

Chapter

Chapter 10

Events and Submissions/Topic

Week 4 Begin Date: 27 Mar 2017

Module/Topic

Advanced GUI

Chapter

Chapters 12 and 22

Events and Submissions/Topic

Week 5 Begin Date: 03 Apr 2017

Module/Topic

Exception Handling, Files, Streams and Object Serialization

Chapter

Chapters 11 and 15

Events and Submissions/Topic

Vacation Week Begin Date: 10 Apr 2017

Module/Topic

Chapter

Events and Submissions/Topic

Week 6 Begin Date: 17 Apr 2017

Module/Topic

Object-Oriented Design

Chapter

Chapter 33 (online chapter): Object-Oriented Design with the UML

Events and Submissions/Topic

Assignment 1 Due: Week 6 Thursday (20 Apr 2017) 11:45 pm AEST
Week 7 Begin Date: 24 Apr 2017

Module/Topic

Generic Collections and Iterators

Chapter

Chapter 16

Events and Submissions/Topic

Week 8 Begin Date: 01 May 2017

Module/Topic

Algorithmic Efficiency, Lambdas and Streams

Chapter

Chapters 19 and 17

Events and Submissions/Topic

Week 9 Begin Date: 08 May 2017

Module/Topic

Accessing Databases with JDBC

Chapter

Chapter 24

Events and Submissions/Topic

Week 10 Begin Date: 15 May 2017

Module/Topic

Generic Classes and Methods

Chapter

Chapter 20

Events and Submissions/Topic

Week 11 Begin Date: 22 May 2017

Module/Topic

Custom Generic Data Structures

Chapter

Chapter 21

Events and Submissions/Topic

Assignment 2 Due: Week 11 Thursday (25 May 2017) 11:45 pm AEST
Week 12 Begin Date: 29 May 2017

Module/Topic

Recursion

Chapter

Chapter 18

Events and Submissions/Topic

Review/Exam Week Begin Date: 05 Jun 2017

Module/Topic

Chapter

Events and Submissions/Topic

Exam Week Begin Date: 12 Jun 2017

Module/Topic

Chapter

Events and Submissions/Topic

Term Specific Information

Unit Coordinator

Dr. Mary Tom

School of Engineering & Technology

Central Queensland University

Brisbane QLD 4000, Australia

Phone: +61 7 3295 1119
Email: m.tom@cqu.edu.au

Assessment Tasks

1 Practical and Written Assessment

Assessment Title
Assignment 1

Task Description

In this assignment you will demonstrate your understanding of object oriented programming concepts in Java, and show an ability to develop a GUI (Graphical User Interface) based Java application. This assessment task is to design, code, debug, and test using the topics covered in Weeks 1-5. Further details are available on the unit website in the Assignment 1 Specification document.


Assessment Due Date

Week 6 Thursday (20 Apr 2017) 11:45 pm AEST


Return Date to Students

Week 9 Friday (12 May 2017)


Weighting
15%

Assessment Criteria

  1. Efficient object-oriented program design.
  2. Appropriate use of Graphical User Interface (GUI).
  3. Appropriate use of data structures and algorithms in problem solving.
  4. Effective use of good programming practice/techniques.
  5. Rigorous testing of Java applications


Referencing Style

Submission
Online

Submission Instructions

Learning Outcomes Assessed
  • Choose and compare appropriate data structures in program design.
  • Analyse, develop and implement software solutions with the focus of data structures and algorithms.
  • Apply classes, inheritance, polymorphism and exception handling in the context of data structures and algorithms.


Graduate Attributes
  • Knowledge
  • Communication
  • Cognitive, technical and creative skills
  • Self-management

2 Practical and Written Assessment

Assessment Title
Assignment 2

Task Description

In this assignment you will demonstrate your understanding of object oriented programming concepts and a variety of data structures and algorithms in Java, and show an ability to develop a GUI (Graphical User Interface) based Java application. This assessment task includes design, document, develop code, debug , and test a java application applying topics covered in Weeks 1 - 10. Further details are available on the Moodle unit website in the Assignment 2 specification document.


Assessment Due Date

Week 11 Thursday (25 May 2017) 11:45 pm AEST


Return Date to Students

Exam Week Wednesday (14 June 2017)


Weighting
30%

Assessment Criteria

  1. Efficient object-oriented program design.
  2. Appropriate use of Graphical User Interface (GUI).
  3. Appropriate use of data types and algorithms in problem solving.
  4. Effective use of good programming practice/techniques.
  5. Rigorous testing of Java applications.
  6. Effective evaluation of algorithms, data structures and program designs.


Referencing Style

Submission
Online

Submission Instructions

Learning Outcomes Assessed
  • Compare and contrast different algorithms in problem solving.
  • Choose and compare appropriate data structures in program design.
  • Evaluate a variety of data structures and algorithmic approaches including: recursion, linked lists, stacks, queues, trees, graphs, sorting and searching.
  • Analyse, develop and implement software solutions with the focus of data structures and algorithms.
  • Apply classes, inheritance, polymorphism and exception handling in the context of data structures and algorithms.
  • Programmatically connect to a database and implement the database operations.


Graduate Attributes
  • Knowledge
  • Communication
  • Cognitive, technical and creative skills
  • Research
  • Self-management

Examination

Outline
Complete an invigilated examination

Date
During the examination period at a CQUniversity examination centre

Weighting
55%

Length
180 minutes

Exam Conditions
Open Book

Materials
No calculators permitted
Dictionary - non-electronic, concise, direct translation only (dictionary must not contain any notes or comments).
Academic Integrity Statement

As a CQUniversity student you are expected to act honestly in all aspects of your academic work.

Any assessable work undertaken or submitted for review or assessment must be your own work. Assessable work is any type of work you do to meet the assessment requirements in the unit, including draft work submitted for review and feedback and final work to be assessed.

When you use the ideas, words or data of others in your assessment, you must thoroughly and clearly acknowledge the source of this information by using the correct referencing style for your unit. Using others’ work without proper acknowledgement may be considered a form of intellectual dishonesty.

Participating honestly, respectfully, responsibly, and fairly in your university study ensures the CQUniversity qualification you earn will be valued as a true indication of your individual academic achievement and will continue to receive the respect and recognition it deserves.

As a student, you are responsible for reading and following CQUniversity’s policies, including the Student Academic Integrity Policy and Procedure. This policy sets out CQUniversity’s expectations of you to act with integrity, examples of academic integrity breaches to avoid, the processes used to address alleged breaches of academic integrity, and potential penalties.

What is a breach of academic integrity?

A breach of academic integrity includes but is not limited to plagiarism, self-plagiarism, collusion, cheating, contract cheating, and academic misconduct. The Student Academic Integrity Policy and Procedure defines what these terms mean and gives examples.

Why is academic integrity important?

A breach of academic integrity may result in one or more penalties, including suspension or even expulsion from the University. It can also have negative implications for student visas and future enrolment at CQUniversity or elsewhere. Students who engage in contract cheating also risk being blackmailed by contract cheating services.

Where can I get assistance?

For academic advice and guidance, the Academic Learning Centre (ALC) can support you in becoming confident in completing assessments with integrity and of high standard.

What can you do to act with integrity?