Module Catalogue 2024/25

CSC8023 : Programming and Data Structures

CSC8023 : Programming and Data Structures

  • Offered for Year: 2024/25
  • Module Leader(s): Dr Dan Nesbitt
  • Lecturer: Dr Konrad Dabrowski
  • Teaching Assistant: Mrs Menna Khedr
  • Owning School: Computing
  • Teaching Location: Newcastle City Campus
Semesters

Your programme is made up of credits, the total differs on programme to programme.

Semester 1 Credit Value: 20
ECTS Credits: 10.0
European Credit Transfer System
Pre-requisite

Modules you must have done previously to study this module

Pre Requisite Comment

N/A

Co-Requisite

Modules you need to take at the same time

Co Requisite Comment

N/A

Aims

To provide an introduction to object-oriented design and implementation, software development environments, introduce the concepts of inheritance, exception handling and a selection of algorithms for the Java programming language.

Outline Of Syllabus

• Programs, programming, programming environments.
• Introduction to tooling for version control.
• The Java Programming Language Architecture: JVM, JRE, and JDK.
• Java Programming language fundamentals: types, variables, arithmetic expression, Boolean conditions,
• Objects and methods.
• Data Structures: Arrays, Array Lists, Maps, and Sets
• Control-flow abstractions: 'if', 'while', 'do', 'switch' and 'for' statements; input and output.
• Advanced object-oriented programming concepts: inheritance and polymorphism.
• Exceptions and exception handling in Java.
• Generic classes and methods.
• Simple algorithms: searching, sorting.
• Data structures: stacks and queues and their applications

Learning Outcomes

Intended Knowledge Outcomes

To be able to read and explain simple examples of software code written in an object-oriented programming language.

To be able to describe and discuss some common data structures and their use.

To be able to discuss selected searching and sorting algorithms and their performance.

Intended Skill Outcomes

The ability to use a modern software development environment.

The ability to design, implement, test and debug object-oriented programs.

The ability to improve the structure of Java applications using inheritance and polymorphism.

The ability to reason about algorithms’ performance.

Teaching Methods

Teaching Activities
Category Activity Number Length Student Hours Comment
Guided Independent StudyAssessment preparation and completion140:0040:00Background reading
Scheduled Learning And Teaching ActivitiesLecture381:0038:00Lectures
Structured Guided LearningLecture materials161:0016:00Tutorial (online or in person)
Guided Independent StudyAssessment preparation and completion171:0017:00Revision for end of semester exam and exam duration
Scheduled Learning And Teaching ActivitiesPractical351:0035:00Practical
Guided Independent StudyProject work140:0040:00For Practical/lab report 1 and. Summative Assessment (Quiz).
Scheduled Learning And Teaching ActivitiesScheduled on-line contact time141:0014:00Online tutorials
Total200:00
Teaching Rationale And Relationship

Lectures will be used to introduce the learning material and for demonstrating the key concepts by example. Students are expected to follow-up lectures within a few days by re-reading and annotating lecture notes to aid deep learning.

This is a very practical subject, and it is important that the learning materials are supported by hands-on opportunities provided by practical classes. Students are expected to spend time on coursework outside timetabled practical classes.

Students aiming for distinction marks are expected to widen their knowledge beyond the content of lecture notes through background reading.

Students should set aside sufficient time to revise for the end of semester exam.

Reading Lists

Assessment Methods

The format of resits will be determined by the Board of Examiners

Exams
Description Length Semester When Set Percentage Comment
Digital Examination1201M50Digital based examination with short coding questions
Other Assessment
Description Semester When Set Percentage Comment
Practical/lab report1M50Programming coursework (20 hrs)
Formative Assessments

Formative Assessment is an assessment which develops your skills in being assessed, allows for you to receive feedback, and prepares you for being assessed. However, it does not count to your final mark.

Description Semester When Set Comment
Prob solv exercises1MProgramming quiz
Assessment Rationale And Relationship

Practice in writing programs and using development tools is the most effective way for students to learn software development. The coursework provides further practice in writing programs and using development.

Timetable

Past Exam Papers

General Notes

N/A

Welcome to Newcastle University Module Catalogue

This is where you will be able to find all key information about modules on your programme of study. It will help you make an informed decision on the options available to you within your programme.

You may have some queries about the modules available to you. Your school office will be able to signpost you to someone who will support you with any queries.

Disclaimer

The information contained within the Module Catalogue relates to the 2024 academic year.

In accordance with University Terms and Conditions, the University makes all reasonable efforts to deliver the modules as described.

Modules may be amended on an annual basis to take account of changing staff expertise, developments in the discipline, the requirements of external bodies and partners, and student feedback. Module information for the 2025/26 entry will be published here in early-April 2025. Queries about information in the Module Catalogue should in the first instance be addressed to your School Office.