Fall Hours • COVID-19 Update

The Silicon Valley Campus is open 4–9:30 p.m. on Monday–Friday and 8 a.m.–5 p.m. on Saturday.

All campus visitors must be vaccinated, wear a mask, & submit a COVID symptom check. Visit our COVID page for updates.

Course

C Programming, Advanced | CMPR.X401


C remains one of the most popular programming languages. It is widely available on most, if not all, computing platforms. This language is highly valued for its speed, low-level capabilities and platform independent characteristics. It is also actively used in the development of other languages. This course will broaden your skills as a C language programmer by introducing sophisticated problem-solving and optimization techniques.

This course delves into the design, implementation, and use of advanced data structures. Students will solidify their understanding of strings, arrays, pointers, structures, unions and bit manipulation. Emphasis will be on programming that employs and improves upon a variety of data structures. Through this course, you will learn to write efficient programs by understanding the complexities of various algorithms.

Learning Outcomes:

At the conclusion of the course, you should be able to:

  • Define a data type and understand the memory layout for different variables.
  • Manipulate arrays of any data type, program with loops and control flow, play with pointers.
  • Define user created structures, use files to read the input data and write output.
  • Allocate structure memory dynamically, manipulate linked lists.
  • Sort complex data though simple and advanced sort routines.
  • Create tree structures, assign data elements in tree format and traverse trees.
  • Create a B-Tree structure to store multiple elements of data in a tree node with multiple children.
  • Create graph nodes to traverse through them, find shortest path from a graph between two nodes.
  • Identify a minimum spanning tree of a graph created with the node information.

Topics Include:

  • Data types, variables, operators, and operator precedence
  • Arrays in general, including two-dimensional and multi-dimensional configurations
  • Dynamic memory allocation
  • Pointers, strings, file input and output
  • Data structures such as linked, circular and doubly linked lists, stacks, queues, and hash tables
  • Binary trees in general, including implementation, traversal and drawbacks, AVL trees, B trees, and B+ trees
  • Recursions and implementation of recursive algorithms
  • Huffman algorithm
  • Sorting routines, Big O notation and the complexity of algorithms
  • Graphs: their traversal and applications

Skills Needed: Students should have a good understanding of programming using data types such as pointers, control flow, structures and functions.

Have a question about this course?
Speak to a student services representative.
Call (408) 861-3860
ENROLL EARLY!
  • Save your seat and help us confirm course scheduling. Enroll at least seven days before your course starts.
  • ACCESSING CANVAS—Learn more about accessing your course on Canvas in our FAQ section.

Prerequisite(s):

Course Availability Notification

Please use this form to be notified when this course is open for enrollment.

Contact Us
Speak to a student services representative.

Call (408) 861-3860

Envelope extension@ucsc.edu