一个正整数 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
鸣谢用户 漏穿雪 补充数据!
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
#include<iostream>
#include<math.h>
using namespace std;int main() {int N, mL = 0, start = 0;//mL最大长度,start表示连续因子开始的那个数cin >> N;for (int i = 2; i <= sqrt(N); i++) {long temp = 1;for (int j = i; temp <= N; j++) {if (N % temp == 0 && j - i > mL) {//判断是否为因子,以及长度是否更新mL = j - i;start = i;}if (temp * j <= N) {temp *= j;} else {break;}}}if (mL > 0) {//如果是素数则除了1和本身没有其它因子cout << mL << endl;for (int i = 0; i < mL; i++) {if (i != 0) {cout << "*";}cout << i + start;}} else {cout << 1 << endl << N;}return 0;
}
补充:
范围是从2到sqrtN,因为开根号后面不可能连续
第一重循环定的是开始的因子,第二重循环是从i开始往后找最长的连续因子
注意素数的存在,所以要判断一下最长的长度,如果mL为0,则为素数,输出本身
还有边界值的存在,注意判断条件小于等于
测试点6的数据很大,一开始temp用的int,老是浮点错误
后来用long定义temp,就通过测试点6了