蓝桥杯试题 基础练习 分解质因数
提交此题
资源限制
时间限制:1.0s 内存限制:512.0MB
问题描述
求出区间[a,b]中所有整数的质因数分解。
输入格式
输入两个整数a,b。
输出格式
每行输出一个数的分解,形如k=a1a2a3…(a1<=a2<=a3…,k也是从小到大的)(具体可看样例)
样例输入
3 10
样例输出
3=3
4=22
5=5
6=23
7=7
8=222
9=33
10=25
提示
先筛出所有素数,然后再分解。
数据规模和约定
2<=a<=b<=10000
代码:
#include<iostream>
#include<cmath>
#include<vector>
using namespace std;
bool Isprime(int m);
int main()
{
int n,m;
cin >> n >> m;
vector<int> prime;
int i,j;
for(i = 2;i <= m;i ++)
{
if(Isprime(i))
{
prime.push_back(i);
}
}
int x;
for(i = n;i <= m;i ++)
{
cout << i << "=";
x = i;
for(j = 0;j <= prime.size();)
{
if(x % prime[j] == 0)
{
x /= prime[j];
cout << prime[j];
if(x != 1) cout << "*";
else break;
}
else j ++;
}
cout << endl;
}
return 0;
}
bool Isprime(int m)
{
int i,k;
k = sqrt(m);
for(i = 2;i <= k;i ++)
{
if(m % i == 0)
return false;
}
return true;
}
判断是否是质数的函数 bool Isprime(int m):
这里 i <= k ,而 k 是 m 的平方根:这属于算法上的问题,好好考虑一下算法和素数的定义。为了减少无用的循环,开平方之后的数就不用再除一下判断了。
bool Isprime(int m)
{
int i,k;
k = sqrt(m);
for(i = 2;i <= k;i ++)
{
if(m % i == 0)
return false;
}
return true;
}
上面用到了数学中 sqrt() 求平方根函数,所以头文件加上:
#include<cmath>
接下来讲main()函数中的:
一、其中用到了C++语言中的 vector:
vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库。vector之所以被认为是一个容器,是因为它能够像容器一样存放各种类型的对象**,简单地说,vector是一个能够存放任意类型的动态数组,能够增加和压缩数据。**关于vector函数的具体用法请看链接:
vector具体用法
并且头文件要加上:
#include<vector>