May 26, 2011 at 1:13pm May 26, 2011 at 1:13pm UTC
Nothing hard to do, but I thought it was entertaining while it lasted. Got this task from eulerproject.com - my solution is here (
http://pastebin.com/UZwR4P3z ), I'd really like to see how other people would attempt to do this.
(In case it's not clear - the task is to find the smallest number that is evenly divisible by all numbers from 1 to the specified range).
Last edited on May 26, 2011 at 1:17pm May 26, 2011 at 1:17pm UTC
May 26, 2011 at 1:55pm May 26, 2011 at 1:55pm UTC
My compiler don't know what auto is.
I find the lcm using the gcd far more easy.
1 2 3 4 5 6 7 8 9 10 11
number gcd(number a, number b){
if ( b==0 ) return a;
return gcd(b, a%b);
}
number lcm(number a, number b){
return a*b / gcd(a,b);
}
result = 1;
for (int K=1; K<=n; ++K)
result = lcm(K, result);
By the way, when calculating primes the dynamic method is awesome.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25
bool is_prime(number n);
bool is_dyn_prime(number n);
void generate( number limit );
std::vector<number> primes;
bool is_prime(number n){
return binary_search(primes.begin(), primes.end(), n) or is_dyn_prime(n);
}
bool is_dyn_prime(number n){
number root = sqrt(n) + 2; //I don't want issues with precision
for (size_t K=0; K<primes.size() and primes[K]<root; ++K)
if (n%primes[K] == 0)
return false ;
return true ;
}
void generate( number limit ){
if ( limit>=2 )
primes.push_back(2);
for (number K=3; K<=limit; K+=2)
if ( is_dyn_prime(K) )
primes.push_back(K);
}
Last edited on May 26, 2011 at 1:59pm May 26, 2011 at 1:59pm UTC
May 26, 2011 at 2:17pm May 26, 2011 at 2:17pm UTC
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37
#include <iostream>
#include <vector>
struct Eratosthenes{
std::vector<unsigned > sieve;
unsigned p;
Eratosthenes() : p(2) {}
unsigned operator * () const { return p; }
void operator ++ (int ){
sieve.push_back( p );
bool composite = true ;
while ( composite ){
p++;
composite = false ;
for (int i = 0; i < sieve.size(); i++)
if ( p % sieve[i] == 0 ){
composite = true ;
break ;
}
}
}
};
int main(){
const int N = 10;
int result = 1;
for ( Eratosthenes P; *P <= N; P++ ){
int n = N;
while ( n /= *P ) result *= *P;
}
std::cout << result;
std::cin.get();
return 0;
}
edit: sorry, I keep forgetting which ++ is which..
Oddly VC++ only gives a warning about that.
Last edited on May 26, 2011 at 3:21pm May 26, 2011 at 3:21pm UTC
May 26, 2011 at 2:43pm May 26, 2011 at 2:43pm UTC
ne, what compiler are you using? it's a c++0x feature so maybe you just gotta tell your compiler to compile with 0x support.
May 26, 2011 at 3:06pm May 26, 2011 at 3:06pm UTC
@hamsterman: Great. :)
(but it does not compile)
@hanst99: okay, fixed.
however
1 2 3 4
int main()
{
return getRangeLeastCommonMultiple(NUMBER);
}
¡¿how do you see the output?! It seems that
echo $?
makes % 256
(and using the return code it's just awful)
Last edited on May 26, 2011 at 3:10pm May 26, 2011 at 3:10pm UTC
May 26, 2011 at 3:12pm May 26, 2011 at 3:12pm UTC
Just replace that with any output method of your liking. Visual Studio shows the return code of the program when debugging, so I didn't bother to write actual output code.
May 26, 2011 at 3:15pm May 26, 2011 at 3:15pm UTC
a%b
What if a
is negative?
May 26, 2011 at 3:17pm May 26, 2011 at 3:17pm UTC
You can get a modulo of a negative number.