ITU ACM 2020-2021 Algo101 Course

Prerequisities

  • Basic knowledge about any programming language, preferably C/C++.
  • Having an account on HackerRank.
  • Zoom account.
  • Attendee's own programming environment installed.

Goal

Participants will learn to solve the problems that we encounter in daily life or writing efficient code starting from the basic algorithm information. Competitive Programming will be introduced and we will have the opportunity to apply our knowledge after adapting what we have learned to the question types with the contests related to each week's topic.

Lecture Day & Time

Tuesday 18.00-19.30

Important Links

All sources: https://github.com/inzva/Algorithm-Program

Syllabus

Week Topic Description Instructor
1 Intro + Algorithms - 1 Big O Notation, Recursion, Builtin Data Structures, Sort/Search Algorithms Fatih Avcı
2 Math - 1 Number Theory, Factorization, Combinatorics, Exponentiation Ömer Faruk Özkan
4 Graph - 1 Representing Graphs, Tree Traversals, Binary Search Tree, DFS, BFS, Union Find, Heap Mehmet Altuner
5 DP - 1 Greedy Algorithms, Memoization, Common DP Problems Ali Cafer Özer
6 Data Structures - 1 Stack, Queue, Deque, Linked List, Prefix Sum, Sparse Table, BIT, SQRT Decomposition, Segment Tree Yılmaz Barış Kaplan

Lessons will be around 1:30 - 2 hours

Instructors @I.T.U

Name and Surname Social Media
Yılmaz Barış Kaplan LinkedIn
Mehmet Altuner LinkedIn
Ali Cafer Özer LinkedIn
Ömer Faruk Özkan LinkedIn
Fatih Avcı LinkedIn

Suggested Readings

Each week's inzva bundle before coming to lecture.

ProTip: You can find more information about this course here.