LearnToCP
Sign in
Navigation
HomeRoadmapAbout UsProblems
Theory
Basics
Data types and IOC++ syntaxModuloVectorsMatricesTime Complexity
Sorting
SortingCounting sort
Optimization Techniques I
Two PointersSum of numbers 1 to nPrefix sumBinary Search
Binary Numbers
Binary NumbersNumbers in codeBitwise Operations
Math
Binary Exponentiation

Modulo

In this lesson we will learn about division, and how to find the remainder after dividing by an integer number.

When solving problems we often need to check if two numbers are divisible. The simplest way to check is by using Modulo

What is modulo?

Modulo is a mathematical operations that tells us the remainder after dividing two whole numbers, in math it is written as a mod b, but in c++ we use a % b
Let's look at some examples:

5 % 2 = 1
100 % 10 = 0
9 % 7 = 2

Two numbers are divisible if their modulo equals 0!

If we look at multiple sequential numbers we begin to see a pattern:

3 % 3 = 0
4 % 3 = 1
6 % 3 = 0
7 % 3 = 1

As we can see the result repeats, we can also see that when dividing by n the remainders are:

0, 1, 2, 3, ..., n-2, n-1

Or in other words: numbers from 0 to n-1

Implementation

Implementing modulo is really simple, just type a % b, and we get the result

int main(){

	int a = 5;
	int b = 3;
	
	cout<< a % b;

	return 0;
}

Output: 2

We can also check if two numbers are divisible by using: if(a % b == 0)

int main(){

	cin.tie(0);
	ios_base::sync_with_stdio(false);
	
	int a,b;
	
	cin>>a>>b;
	
	if(a % b ==0){
		cout<<"The numbers are divisible";
	}else{
		cout<<"The numbers are NOT divisible";
	}
	
	return 0;
}

Input: 100 3
Output: The numbers are NOT divisible

Input: 100 5
Output: The numbers are divisible