diff options
| author | Ryan Thompson <rjt-pl@users.noreply.github.com> | 2022-06-16 17:10:46 -0600 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2022-06-16 17:10:46 -0600 |
| commit | c92803076d8d8f9fee7bb945e0e268399e32cdd3 (patch) | |
| tree | f59a55e4a378f42fa80a5b6f13238b12088e7d4b /challenge-169/ulrich-rieke/cpp/ch-1.cpp | |
| parent | 40198d275c123f30a185aea4da69f2c3b9424dab (diff) | |
| parent | 7c2fa584618da574d42b1713c3c343423991c781 (diff) | |
| download | perlweeklychallenge-club-c92803076d8d8f9fee7bb945e0e268399e32cdd3.tar.gz perlweeklychallenge-club-c92803076d8d8f9fee7bb945e0e268399e32cdd3.tar.bz2 perlweeklychallenge-club-c92803076d8d8f9fee7bb945e0e268399e32cdd3.zip | |
Merge branch 'manwar:master' into master
Diffstat (limited to 'challenge-169/ulrich-rieke/cpp/ch-1.cpp')
| -rw-r--r-- | challenge-169/ulrich-rieke/cpp/ch-1.cpp | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/challenge-169/ulrich-rieke/cpp/ch-1.cpp b/challenge-169/ulrich-rieke/cpp/ch-1.cpp new file mode 100644 index 0000000000..2d4d8011f4 --- /dev/null +++ b/challenge-169/ulrich-rieke/cpp/ch-1.cpp @@ -0,0 +1,46 @@ +#include <iostream> +#include <vector> +#include <string> +#include <algorithm> + +std::vector<int> primeDecompose( int n ) { + std::vector<int> primeFactors ; + int current = 2 ; + while ( n != 1 ) { + if ( n % current == 0 ) { + primeFactors.push_back( current ) ; + n /= current ; + } + else { + current++ ; + } + } + return primeFactors ; +} + +bool isBrilliant( int n ) { + std::vector<int> primeFactors( primeDecompose( n ) ) ; + if ( primeFactors.size( ) == 2 ) { + std::vector<std::string> primeNumbers( 2 ) ; + std::transform( primeFactors.begin( ) , primeFactors.end( ) , + primeNumbers.begin( ) , []( int i ){ return std::to_string( i ) ;} ) ; + return primeNumbers.begin()->length( ) == primeNumbers.back().length( ) ; + } + else { + return false ; + } +} + +int main( ) { + std::vector<int> brilliantNumbers ; + int current = 2 ; + while ( brilliantNumbers.size( ) != 20 ) { + if ( isBrilliant( current ) ) + brilliantNumbers.push_back( current ) ; + current++ ; + } + for ( int i : brilliantNumbers ) + std::cout << i << " " ; + std::cout << std::endl ; + return 0 ; +} |
