将maxn以内的素数存入数组prime中
code:
void get_prime(){
isprime[1]=1;
for(int i=2;i*i<=maxn;i++){
if(!isprime[i]){
for(int j=i*i;j<maxn;j+=i)
isprime[j]=1;
}
}
for(int j=2;j<=maxn;j++){
if(!isprime[j]) prime[cnt++]=j;
}
}
唯一分解定理
code:
void cal(int n){
ma.clear();
for(int i=0;i<cnt&&prime[i]*prime[i]<=n;i++){
while(n%prime[i]==0){
ma[prime[i]]++;
n/=prime[i];
}
}
if(n>1) ma[n]++;
}
试题 基础练习 分解质因数
资源限制
时间限制:1.0s 内存限制:512.0MB
问题描述
求出区间[a,b]中所有整数的质因数分解。
输入格式
输入两个整数a,b。
输出格式
每行输出一个数的分解,形如k=a1*a2*a3...(a1<=a2<=a3...,k也是从小到大的)(具体可看样例)
样例输入
3 10
样例输出
3=3
4=2*2
5=5
6=2*3
7=7
8=2*2*2
9=3*3
10=2*5
提示
先筛出所有素数,然后再分解。
数据规模和约定
2<=a<=b<=10000
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<vector>
#include<map>
using namespace std;
const int maxn=1e4+10;
bool isprime[maxn];
int prime[maxn];
//int a[100];
int cnt,num;
map<int,int> ma;
void get_prime(){
isprime[1]=1;
for(int i=2;i*i<=maxn;i++){
if(!isprime[i]){
for(int j=i*i;j<maxn;j+=i)
isprime[j]=1;
}
}
for(int j=2;j<=maxn;j++){
if(!isprime[j]) prime[cnt++]=j;
}
}
void cal(int n){
ma.clear();
printf("%d=",n);
for(int i=0;i<cnt&&prime[i]*prime[i]<=n;i++){
while(n%prime[i]==0){
ma[prime[i]]++;
n/=prime[i];
}
while(ma[prime[i]]--){
if(n==1&&ma[prime[i]]==0)
printf("%d",prime[i]);
else printf("%d*",prime[i]);
}
}
if(n>1) printf("%d",n);
}
int main(){
int a,b;
get_prime();
scanf("%d%d",&a,&b);
for(int i=a;i<=b;i++){
cal(i);
printf("\n");
}
return 0;
}