使用平方根的偶数除数
Number of even divisors using square root
我正在解决一个问题,它需要得到偶数和奇数除数之间的差异,我需要使用 sqrt() 函数,因为数字的限制是 10^9 所以循环整数不是一个选项,因为超过了时间限制。
这是我尝试创建的一个函数,但它并不适用于所有数字。
例如。 4 & 48745.
情况 4:应该输出 2 个偶数因子 {2,4} 和 1 个奇数因子 {1} -- 下面的函数输出 3 even 1 odd
Case 48745 :should output 0 even divisors and 4 odd divisors {1,5,9749,48745} -- 下面的函数输出 2 even 2 odd
int di(int x)
{
int even=0,odd=0;
for(int i=1;i<=sqrt(x);i++)
{
if(x%i==0)
{
if(i%2)
odd++;
else
even++;
if(x/i %2==0 && x/i!=i)
even++;
else if(x/i!=i)
odd++;
}
}
return even-odd;
}
尝试更简单的代码:
#include <iostream>
#include <cmath>
int divdiff(int x)
{
unsigned int even = 0;
unsigned int odd = 0;
const unsigned int sqrtx = std::sqrt(x);
for (int i = 1 ; i <= sqrtx ; ++i)
{
if (x % i == 0)
{
if (i % 2 == 0)
{
++even;
}
else
{
++odd;
}
}
}
even *= 2;
odd *= 2;
if (x == sqrtx * sqrtx)
{
if (x % 2 == 0)
{
--even;
}
else
{
--odd;
}
}
std::cerr << __func__ << '(' << x << "): even=" << even << ", odd=" << odd << std::endl;
return even - odd;
}
int main()
{
std::cout << divdiff(2*2) << std::endl;
std::cout << divdiff(2*3) << std::endl;
std::cout << divdiff(3*3) << std::endl;
std::cout << divdiff(7*11*13*17*23) << std::endl;
}
我正在解决一个问题,它需要得到偶数和奇数除数之间的差异,我需要使用 sqrt() 函数,因为数字的限制是 10^9 所以循环整数不是一个选项,因为超过了时间限制。
这是我尝试创建的一个函数,但它并不适用于所有数字。
例如。 4 & 48745.
情况 4:应该输出 2 个偶数因子 {2,4} 和 1 个奇数因子 {1} -- 下面的函数输出 3 even 1 odd
Case 48745 :should output 0 even divisors and 4 odd divisors {1,5,9749,48745} -- 下面的函数输出 2 even 2 odd
int di(int x)
{
int even=0,odd=0;
for(int i=1;i<=sqrt(x);i++)
{
if(x%i==0)
{
if(i%2)
odd++;
else
even++;
if(x/i %2==0 && x/i!=i)
even++;
else if(x/i!=i)
odd++;
}
}
return even-odd;
}
尝试更简单的代码:
#include <iostream>
#include <cmath>
int divdiff(int x)
{
unsigned int even = 0;
unsigned int odd = 0;
const unsigned int sqrtx = std::sqrt(x);
for (int i = 1 ; i <= sqrtx ; ++i)
{
if (x % i == 0)
{
if (i % 2 == 0)
{
++even;
}
else
{
++odd;
}
}
}
even *= 2;
odd *= 2;
if (x == sqrtx * sqrtx)
{
if (x % 2 == 0)
{
--even;
}
else
{
--odd;
}
}
std::cerr << __func__ << '(' << x << "): even=" << even << ", odd=" << odd << std::endl;
return even - odd;
}
int main()
{
std::cout << divdiff(2*2) << std::endl;
std::cout << divdiff(2*3) << std::endl;
std::cout << divdiff(3*3) << std::endl;
std::cout << divdiff(7*11*13*17*23) << std::endl;
}