L1-006 连续因子 (20分)
一个正整数 N 的因子中可能存在若干连续的数字。例如 630 可以分解为 3×5×6×7,其中 5、6、7 就是 3 个连续的数字。给定任一正整数 N,要求编写程序求出最长连续因子的个数,并输出最小的连续因子序列。
输入格式:
输入在一行中给出一个正整数 N(1<N<231 )。
输出格式:
首先在第 1 行输出最长连续因子的个数;然后在第 2 行中按 因子1因子2……*因子k 的格式输出最小的连续因子序列,其中因子按递增顺序输出,1 不算在内。
输入样例:
630
输出样例:
3
5*6*7
#include<iostream>
#include<cmath>
using namespace std;
int isPerim(int n){
for(int i = 2; i < sqrt(n); i++){
if(n % i == 0){
return 0;
}
}
return 1;
}
int main(){
//定义最大长度值初始值为0.最大长度为max_long,
int n, max_size = 0, max_long = 0, sum = 1, i, j;
cin >> n;
//为了减少复杂度,所以先判断是否为素数,如果是则直接输出1和其本身
if(isPerim(n)){
cout << 1 << endl;
cout << n;
return 0;
}
//进行2-n的遍历
for(i = 2; i < sqrt(n) + 2; i++){
//如果是因子则进入循环
if(n % i == 0){
//防止将i的值改变
sum = i;
for(j = i + 1; j < sqrt(n) + 2; j++){
sum *= j;
//当取模后不为0时则证明已经是最大界限
if(n % sum != 0){
break;
}
}
//j-i即最大度。i为起始点
if(max_size < j - i){
max_size = j - i;
max_long = i;
}
}
}
//首先输出最大长度
cout << max_size << endl;
//输出数据
while(max_size > 0){
max_size--;
cout << max_long++;
//当等于0时意为是最后一个则不需要输出*
if(max_size != 0){
cout << "*";
}
}
return 0;
}