Use the Tab and Up, Down arrow keys to select menu items.
An introduction to Computer Science, including algorithms, complexity and data structures.
The summer version of COSC122 requires you to be on site at Canterbury for an initial block course from November 25 to December 2 (2024) and the final exam in February, but the remainder of the course may be taken by self-paced distance study if necessary. Tutoring is available on campus during the summer, but if you are out of town for some of the time, you will have access to online tutoring help. In either case, you will need to be able to work independently. The course is not available as a full distance (D) course. COSC122SU is intended for students who have completed COSC121 or COSC131, and need COSC122 to be able to advance in Software Engineering or 200-level Computer Science.
1. Analyse algorithms and estimate their worst-case and average-case behaviour (in simple cases) including the application of asymptotic complexity ("big-O" notation) [WA1, WA2, WA7]2. Discuss how the algorithm and data structure used to solve a problem will be the main factor in how quickly it is solved across a range of areas of computer science [WA1, WA5]3. Analyse general algorithmic problem types, particularly in sorting, searching, and graph algorithms [WA1, WA2]4. Choose and justify the choice of common data structures (linked lists, stacks, queues, hash tables, trees, priority queues, graphs) [WA1, WA2, WA3]5. Implement and empirically compare fundamental algorithms and data structures for practical problems [WA1, WA3, WA7]
This course will provide students with an opportunity to develop the Graduate Attributes specified below:
Employable, innovative and enterprising
Students will develop key skills and attributes sought by employers that can be used in a range of applications.
COSC121 or COSC131
Students must attend one activity from each section.
Tim Bell
The lecture and lab schedule can be confusing to read in the format above; put simply, the week-long block course is scheduled from 9am to 5pm each day (except we finish at 3pm on Friday) for the week of 25 November 2024, followed by a test on Monday 2 December 2024. This “intensive” week will be a mixture of lectures and lab sessions. Apart from this, the only other time you are expected to be on campus is for the final exam, as the rest of the work can be done remotely, with support available from staff online. Test: 20% - Test at the end of the block course, 1 hour, from 1-2pm on Monday 2 December 2024. This test will count towards your final grade only if it improves your mark. Assignments: 15% Lab Quizzes: 10% Final Test: 55% - To be held onsite at UC on Wednesday 5th February 2025. Special arrangements may be possible for sitting off-site if necessary, but students would need to organise these at their own expense, and such arrangements need to be discussed, and approved, well in advance.
Miller, Bradley N. & Ranum, David L; Problem solving with algorithms and data structures using Python ; Franklin, Beedle & Associates.
This can be bought from the bookshop, and is also available online at no charge at:https://runestone.academy/ns/books/published/pythonds/index.html.
Library portalCourse Information on Learn STAR COSC122 Information
There are several important documents available online about departmental regulations, policies and guidelines. We expect all students to be familiar with these. Notices about this class will be posted to the class forum in the Learn system.COSC students will also be made members of a class called “CSSE Notices”, where general notices will be posted that apply to all classes (such as information about building access or job opportunities).
Every year several students fail the course because of dishonest practice. Please do not be among them. You are encouraged to discuss the general aspects of a problem with others. However, anything you submit for credit must be entirely your own work and not copied, with or without modification, from any other person. If you share details of your work with anybody else then you are likely to be in breach of the University's General Course and Examination Regulations and/or Computer Regulations (both of which are set out in the University Calendar) and/or the Computer Science Department's policy (see section 9). The Department treats cases of dishonesty very seriously and, where appropriate, will not hesitate to notify the University Proctor.If you need help with specific details relating to your work, or are not sure what you are allowed to do, then contact your tutors or lecturer for advice.
The Computer Science department's grading policy states that in order to pass a course you must meet two requirements:1. You must achieve an average grade of at least 50% over all assessment items.2. You must achieve an average mark of at least 45% on invigilated assessment items.If you satisfy both these criteria, your grade will be determined by the following University-wide scale for converting marks to grades: an average mark of 50% is sufficient for a C- grade, an average mark of 55% earns a C grade, 60% earns a C+ grade and so forth. However if you do not satisfy both the passing criteria you will be given either a D or E grade depending on marks. Marks are sometimes scaled to achieve consistency between courses from year to year.Students may apply for special consideration if their performance in an assessment is affected by extenuating circumstances beyond their control.Applications for special consideration should be submitted via the Examinations Office website within five days of the assessment. Where an extension may be granted for an assessment, this will be decided by direct application to the Department and an application to the Examinations Office may not be required. Special consideration is not available for items worth less than 10% of the course.Students prevented by extenuating circumstances from completing the course after the final date for withdrawing, may apply for special consideration for late discontinuation of the course. Applications must be submitted to the Examinations Office within five days of the end of the main examination period for the semester.
The topics covered in lectures will be as follows. The main references are for the current edition of the text book (2nd edition and online). Where a reference is given in square brackets, it is for the first edition.• Introduction to algorithms, and the relationship with Software Engineering• Algorithm analysis (Chapter 2 [4])• Basic data structures – stacks and queues (Chapter 3 [2])• Lists (Chapter 3 [7])• Recursion (Chapter 4 [3])• Searching (Chapter 5 [4])• Sorting (Chapter 5 [4])• Trees – binary trees and heaps (Chapter 6 [5])• Graphs (Chapter 7 [6])• Overview of major ideas in Computer Science
The course assumes that you are proficient in Python, as taught in COSC121 or COSC131. If you are enrolling in COSC122 but haven't already passed COSC121, COSC131, or the equivalent, you should consult the course supervisor before enrolling.
Domestic fee $942.00
International fee $4,988.00
* All fees are inclusive of NZ GST or any equivalent overseas tax, and do not include any programme level discount or additional course-related expenses.
For further information see Computer Science and Software Engineering .