L1-006. 连续因子
时间限制
400 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
陈越
一个正整数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
思路:
数据量不大,可以直接暴力求解,最大数据位于12的阶乘到13的阶乘之间,所以最多有12个连续相乘的因子。接下来我们就将因子的数量len从12枚举到1,因为因子1不算,所以start从2开始枚举,那么start到哪个数结束呢?很多人肯会说N-1,也有人会说是sqrt(n)-1;,其实应该是到sqrt(n)。连续因子存在则至少需要两个,这个时候需要注意了,长度最长,因子序列最小,比如9,应该输出1 3,如果是到sqrt(n)为止,则是输出1 9,不符合规则。然后把start到start+len-1的数乘起来用ans保存,如果n mod ans==0,那么该连续因子就是符合条件的因子,同时需要注意没有因子的数,比如质数,最后应该输出它本身。
#include<bits/stdc++.h>
using namespace std;
int main(){
int n,i,j,k,len;
cin>>n;
int MAX = sqrt(n);
for(len = 12;len >= 1;len--){
for(int start = 2;start <= MAX;start++){
long long ans = 1;
for(i = start;i - start<len;i++)
ans *= i;
if(n % ans == 0) {
printf("%d\n%d", len, start);
for(int i = start + 1; i - start <= len - 1; i++)
printf("*%d", i);
return 0;
}
}
}
printf("1\n%d",n);
return 0;
}