open-cpp-utils 0.0.1
Loading...
Searching...
No Matches
math.h
1// =====================================================================================================================
2// open-cpp-utils, an open-source cpp library with data structures that extend the STL.
3// Copyright (C) 2024 Medusa Slockbower
4//
5// This program is free software: you can redistribute it and/or modify
6// it under the terms of the GNU General Public License as published by
7// the Free Software Foundation, either version 3 of the License, or
8// (at your option) any later version.
9//
10// This program is distributed in the hope that it will be useful,
11// but WITHOUT ANY WARRANTY; without even the implied warranty of
12// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13// GNU General Public License for more details.
14//
15// You should have received a copy of the GNU General Public License
16// along with this program. If not, see <https://www.gnu.org/licenses/>.
17// =====================================================================================================================
18
19#ifndef OPEN_CPP_UTILS_MATH_H
20#define OPEN_CPP_UTILS_MATH_H
21
22#include <cmath>
23
24namespace open_cpp_utils
25{
26
27template<typename T>
28bool is_prime(T x)
29{
30 if(x <= 1) return false;
31 if(x == 2 || x == 3) return true;
32 if(x % 2 == 0 || x % 3 == 0) return false;
33
34 T limit = static_cast<T>(sqrt(x));
35 for(T i = 5; i <= limit; i += 6)
36 {
37 if(x % i == 0 || x % (i + 2) == 0) return false;
38 }
39
40 return true;
41}
42
43}
44
45#endif // OPEN_CPP_UTILS_MATH_H