Back to Courses
MATH002 Undergraduate

Discrete Mathematics

An introductory course in discrete mathematics for mathematics and computer science majors. It covers fundamental topics such as logic, sets, proof techniques, algorithms, number theory, combinatorics, graph theory, and automata. The course emphasizes mathematical reasoning and problem-solving skills necessary for advanced study in computer science.

5.0
36.0h
1043 students
0 likes
Math
Start Learning

Lessons

Lesson

This lesson introduces the fundamental principles of set theory, emphasizing that sets are unordered collections defined by their members rather than their sequence. It explores how set operations like union, intersection, and power sets function as the structural foundations for logical operators and deductive reasoning.

This lesson explores the anatomy of a mathematical system, explaining how undefined terms, axioms, definitions, and proofs form a logical hierarchy to establish truth. Students will learn how these foundational components prevent circular reasoning and serve as the basis for constructing theorems, lemmas, and corollaries.

This lesson explores the fundamental principles of mathematical mappings, defining functions as precise, deterministic relationships between domains and codomains. Students will learn to evaluate algorithmic correctness using loop invariants and apply discrete structures like sequences and relations to model computational data.

This lesson introduces the fundamental definition of an algorithm as a finite, deterministic, and general sequence of steps used to solve a specific class of problems. Students will learn to verify algorithmic logic through pseudocode and manual tracing while exploring mathematical concepts like divisibility that underpin effective problem-solving.

This lesson explores the transition from continuous calculus to discrete mathematics, highlighting how number theory and prime factorization provide the foundation for modern cryptographic systems like RSA. Students will learn to apply mathematical induction for algorithmic verification and master the mechanics of divisibility to understand the security of one-way "trapdoor" functions.

This lesson introduces the fundamental principles of counting, teaching students how to use the Addition Principle for mutually exclusive choices and the Multiplication Principle for successive, independent steps. By mastering these rules and techniques like complementary counting, students learn to efficiently determine the size of finite sets and solve complex combinatorial problems.

This lesson explores recurrence relations as a framework for modeling combinatorial sequences, such as Stirling and Catalan numbers, and analyzing the efficiency of algorithms like binary search and selection sort. Students will learn to solve linear homogeneous relations using characteristic equations and apply recursive modeling to complex problems like the Tower of Hanoi and derangements.

This lesson introduces the fundamentals of graph theory, defining graphs as sets of vertices and edges used to model complex networks and connectivity. Students will learn to identify graph types, analyze paths and subgraphs, and apply the Handshaking Lemma to solve structural problems.

This lesson introduces the fundamental concepts of tree structures in graph theory, covering the distinction between free and rooted trees and the hierarchical terminology used to describe them. Students will learn how these mathematical models serve as essential frameworks for organizing data and solving complex optimization problems in real-world applications.

This lesson introduces transport networks as directed, weighted graphs defined by a source with no incoming edges, a sink with no outgoing edges, and non-negative capacities on all edges. Students learn to distinguish between these structural capacity limits and the actual flow of commodities through a system.

This lesson explores combinatorial logic, defining it as a system where circuit outputs are determined solely by current inputs without the use of memory or feedback. Students learn to map Boolean algebraic expressions directly onto physical circuit topologies using structural induction, operator precedence, and efficient n-input gate designs.

This lesson introduces sequential logic by distinguishing it from memoryless combinatorial circuits through the use of unit time delays and feedback loops. Students will learn how these components enable the creation of finite-state machines, which allow systems to store information and base future outputs on past states.

Course Overview

📚 Content Summary

An introductory course in discrete mathematics for mathematics and computer science majors. It covers fundamental topics such as logic, sets, proof techniques, algorithms, number theory, combinatorics, graph theory, and automata. The course emphasizes mathematical reasoning and problem-solving skills necessary for advanced study in computer science.

Master the logic and structures that form the foundation of computer science.

Author: Richard Johnsonbaugh

Acknowledgments: Reviewers including Venkata Dinavahi, Matthew Elsey, Christophe Giraud-Carrier, Yevgeniy Kovchegov, Filix Maisch, Tyler McMillen, Christopher Storm, Donald Vestal, and Guanghua Zhao. Support from Pearson staff: Deirdre Lynch, Jeff Weidenaar, Lauren Morse, and others.

🎯 Learning Objectives

  1. Perform operations on sets, including differences and complements, and verify set identities using Venn diagrams and Theorem 1.1.22.
  2. Construct and evaluate truth tables for propositions involving negation, disjunction, and conditional statements.
  3. Apply rules of inference and deductive reasoning to determine the validity of logical arguments.
  4. Define and apply components of a mathematical system, including axioms, definitions, and theorems.
  5. Construct direct proofs, proofs by contradiction, and proofs by cases for algebraic and set-theoretic propositions.
  6. Utilize the Principle of Mathematical Induction and Strong Induction to prove identities, divisibility properties, and algorithmic correctness.
  7. Define and classify functions (injective, surjective, bijective) and perform operations such as composition and inversion.
  8. Apply sequence notation, string concatenation, and recursive rules to model discrete data sets.
  9. Analyze binary relations for properties like reflexivity, symmetry, and transitivity using both digraphs and matrix representations.
  10. Define an algorithm and verify its seven core properties (Input, Output, Precision, Determinism, Finiteness, Correctness, and Generality).

Lessons