std::map <int,int> 增量
std::map <int,int> increment
>我正在尝试编写一个函数,该函数将返回给定数字的素因数分解(作为解决欧拉项目问题#12的一部分)。计算质因数。我用std::map
.代码如下:
#include "stdafx.h"
#include <iostream>
#include <map>
#include <algorithm>
bool IsPrime(unsigned int number)
{
if (number < 1) return 0; // zero is not prime. For our purposes, one would be.
for (unsigned int i = 2; i*i <= number; ++i)
{
if (number % i == 0)
return false;
}
return true;
}
int divisors(unsigned int num)
{
int orig_num = num;
std::map <int, int> primefactors;
for(unsigned int i = 1; i <= num; ++i)
if (num % i == 0 && IsPrime(i))
{
num /= i;
++primefactors[i];
std::cout << primefactors[i] << "t";
}
std::cout << orig_num << " = ";
for(auto& iter:primefactors)
std::cout << iter.first << "^" << iter.second << " * ";
return 0;
}
int main()
{
divisors(661500);
return 0;
}
问题是primefactors
的所有计数都返回为 1,尽管 main
中的数字被专门选择为素数大于 1 次方的乘积 (661500 = 1^1*2^2*3^3*5^3*7^2)。我的猜测是我正在增加错误的东西。
每个素数只除一次。但是你应该继续除以素数,只要数字可以被它整除:
for(unsigned int i = 2; i <= num; ++i)
if (IsPrime(i))
{
while (num % i == 0) {
num /= i;
++primefactors[i];
std::cout << primefactors[i] << "t";
}
}
实际上不需要IsPrime(i)
条件:
for(unsigned int i = 2; i <= num; ++i)
while (num % i == 0) {
num /= i;
++primefactors[i];
std::cout << primefactors[i] << "t";
}
证明:如果i
不是素数,则条件num % i == 0
意味着num
可以被i
的素因数p
整除。但是p < i
所以我们的循环必须在i
之前经过一段时间p
。while
循环将有效地消除num
中所有p
的发生。特别是当for
达到i
时,我们有了num
不再能被p
整除。矛盾。即在上面的循环中,如果满足num % i == 0
,则i
是素数。
相关文章:
- 为什么在全局范围内使用"extern int a"似乎不行?
- int(c) 和 c-'0' 之间的区别。C++
- 从"int*"强制转换为"unsigned int"会丢失精度错误
- 增量运算符与后缀混淆
- 为什么野牛仍在使用"int yylex(void)",却找不到"int yylex(YYS
- 有符号的int和int-有没有一种方法可以在C++中区分它们
- 请解释这句话(cout<<1+int((a<b)^((b-a)&1) )<<endl
- 是否可以从int转换为enum类类型
- 不能在初始值设定项列表中将非常量表达式从类型 'int' 缩小到'unsigned long long'
- 向量 <int> a {N, 0} 和 int arr a[N] = {0} 的时间复杂度有什么区别
- 'short int'持有的值溢出,但"自动"不会溢出?
- 如何在C++中将一个无符号的 int 转换为两个无符号的短裤?
- 调用'begin(int [n])'没有匹配函数
- 没有显式声明的int[]中的foreach
- 在c++中访问int到类对象的映射时出错
- OpenMP增量在线程之间添加int
- std::map <int,int> 增量
- 当变量达到最大值时,unsigned int的增量是否会导致未定义的行为
- C++中后缀增量运算符中int变量的含义
- 应该QT阻塞在int增量上