蓝桥杯试题 基础练习 分解质因数

蓝桥杯试题 基础练习 分解质因数
提交此题
资源限制
时间限制:1.0s 内存限制:512.0MB
问题描述
  求出区间[a,b]中所有整数的质因数分解。
输入格式
  输入两个整数a,b。
输出格式
  每行输出一个数的分解,形如k=a1a2a3…(a1<=a2<=a3…,k也是从小到大的)(具体可看样例)
样例输入
3 10
样例输出
3=3
4=22
5=5
6=2
3
7=7
8=222
9=33
10=2
5
提示
  先筛出所有素数,然后再分解。
数据规模和约定
  2<=a<=b<=10000
代码:

#include
#include
#include
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

接下来讲main()函数中的:
一、其中用到了C++语言中的 vector:
vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库。vector之所以被认为是一个容器,是因为它能够像容器一样存放各种类型的对象**,简单地说,vector是一个能够存放任意类型的动态数组,能够增加和压缩数据。**关于vector函数的具体用法请看链接:
vector具体用法

并且头文件要加上:

#include

你可能感兴趣的:(蓝桥杯试题 基础练习 分解质因数)