トップページへ

2025 (Current Year) Faculty Courses School of Computing Undergraduate major in Mathematical and Computing Science

Introduction to Algorithms and Data Structures

Academic unit or major
Undergraduate major in Mathematical and Computing Science
Instructor(s)
Kenji Yasunaga / Yusuke Yoshida
Class Format
Lecture/Exercise (Face-to-face)
Media-enhanced courses
-
Day of week/Period
(Classrooms)
5-8 Tue / 5-6 Fri
Class
-
Course Code
MCS.T213
Number of credits
210
Course offered
2025
Offered quarter
2Q
Syllabus updated
Mar 27, 2025
Language
Japanese

Syllabus

Course overview and goals

A procedure for solving a given problem is called "Algorithm". Efficient algorithms often require well-designed data structure. In this course, we deal with typical algorithms and data structures, their computational complexity and their implementation by C programming language.
Since algorithm is a concrete procedure for solving problems, algorithm is foundation of all information processing, and used everywhere in real world. Learning algorithm is quite important, and could affects our thoughts.

Course description and aims

(1) Able to explain algorithms based on modulo arithmetic, divide and conquer, dynamic programming, etc., and evaluate their computational complexity.
(2) Able to explain data structures such as heaps, binary search trees, etc., along with their implementation methods and evaluate the computational complexity of each operation.
(3) Implement the above algorithms and data structures using the C language.

Keywords

Modulo Arithmetic, Heaps, Binary Search Trees, Fast Fourier Transform, Graph Algorithms, Dynamic Programming

Competencies

  • Specialist skills
  • Intercultural skills
  • Communication skills
  • Critical thinking skills
  • Practical and/or problem-solving skills

Class flow

Lectures are held on Tuesdays and Fridays 5-6 periods
Exercises are held on Tuesdays 7-8 periods at the computer laboratory

Course schedule/Objectives

Course schedule Objectives
Class 1 Algorithm and Computational Complexity: Fibonacci Numbers, Computational Complexity, Big O Notation, Introduction to C Language Understand the computational complexity of algorithms and the big O notation.
Class 2 [Exercise 1]: Introduction to C Language, Fibonacci Numbers Become able to write basic C language code.
Class 3 Modular Arithmetic 1: Computational Complexity of Arithmetic Operations, Modular Arithmetic, Modular Exponentiation (Repeated Squaring), Euclidean Algorithm, Primality Testing, Loop Invariants Understand modulo arithmetics and their computational complexity, the Euclidean algorithm, and loop invariants.
Class 4 Data Structures 1: Operations on Dynamic Sets, Priority Queues, Heaps Understand operations on dynamic sets, priority queues, and heaps.
Class 5 [Exercise] Modular Arithmetic Become able to write modulo arithmetic algorithms in the C programming language.
Class 6 Data Structures 2: Binary Search, Linked Lists, Stacks, Queues Understand binary search and data structures such as linked lists.
Class 7 Data Structures 3: Binary Search Trees, Balanced Search Trees, Hashing Understand binary search trees, balanced search trees, and hashing methods.
Class 8 [Exercise 3]: Heaps Become able to write heaps in the C programming language.
Class 9 Divide and Conquer 1: Karatsuba Algorithm, Master Theorem, Merge Sort, Lower Bounds on Sorting Algorithms Understand divide and conquer algorithms such as the Karatsuba algorithm and be able to evaluate their computational complexity.
Class 10 Divide and Conquer 2: Median Finding, Matrix Multiplication (Strassen's Algorithm) Understand algorithms such as median finding and matrix multiplication using divide and conquer techniques.
Class 11 [Exercise 4]: Data Structure, Divide and Conquer Implement algorithms such as divide and conquer based on data structures in the C programming language.
Class 12 Fast Fourier Transform 1: Polynomial Coefficient Representation and Value Representation, Polynomial Evaluation and Interpolation, Vandermonde Matrix Understand polynomial coefficient representation, value representation, polynomial evaluation, and polynomial interpolation.
Class 13 Fast Fourier Transform 2: Fast Fourier Transform (FFT), Applications of FFT Understand the Fast Fourier Transform.
Class 14 [Exercise 5]: Fast Fourier Transform Implement the Fast Fourier Transform in the C programming language.
Class 15 Graph Algorithms 1: Graph Representation, Depth-First Search, Reachability, Connected Components Understand depth-first search, reachability, and connected components for graphs.
Class 16 Graph Algorithms 2: Breadth-First Search, Shortest Paths, Dijkstra's Algorithm Understand breadth-first search, shortest path, and Dijkstra's algorithm for graphs.
Class 17 [Exercise 6]: Graph Algorithms Implement graph algorithms in C language.
Class 18 Dynamic Programming: Shortest Paths, Longest Increasing Subsequence, Edit Distance Understand dynamic programming.
Class 19 Dynamic Programming: Knapsack Problem, Memoization, Matrix Chain Multiplication Understand dynamic programming for various problems.
Class 20 [Exercise 7]: Dynamic Programming Implement dynamic programming in C.
Class 21 Advanced Topics (e.g., Quantum Algorithms, Disjoint Set Data Structure) Understand advanced topics related to algorithms and data structures.

Study advice (preparation and review)

To enhance effective learning, students are encouraged to spend a certain length of time outside of class on preparation and review (including for assignments). They should do so by referring to textbooks and other course material.

Textbook(s)

None required

Reference books, course materials, etc.

T. Cormen, C. Leiserson, R. Rivest, and C. Stein, Introduction to Algorithms, 4th edition, MIT Press, 2022
S. Dasgupta, C. H. Papadimitriou, and U. V. Vazirani, Algorithms, McGraw-Hill, 2006

Evaluation methods and criteria

In-class quizzes: 30%
Homework-style reports: 30%
Programming exercises: 40%

Related courses

  • LAS.I121 : Computer Science I
  • LAS.I122 : Computer Science II
  • MCS.T204 : Introduction to Computer Science

Prerequisites

The computer lab is available only to students in the Department of Mathematical and Computational Sciences.
Prerequisites include completion of related courses or equivalent knowledge.