L1-006 连续因子(20 分)

一个正整数 N 的因子中可能存在若干连续的数字。例如 630 可以分解为 3×5×6×7,其中 5、6、7 就是 3 个连续的数字。给定任一正整数 N,要求编写程序求出最长连续因子的个数,并输出最小的连续因子序列。

输入格式:

输入在一行中给出一个正整数 N(1<N<2​31​​)。

输出格式:

首先在第 1 行输出最长连续因子的个数;然后在第 2 行中按 因子1*因子2*……*因子k 的格式输出最小的连续因子序列,其中因子按递增顺序输出,1 不算在内。

输入样例:

630

输出样例:

3
5*6*7

思路 :

题目要求输入一个数,输出最长的最小连续因子,而输出数据特征:起始值,连续长度。由于数N【sqrt(N),N】不可能存在连续因子,所以我们只需在【2,sqrt(N)】区间以不同的起始值,更新最终起始值(start)和连续因子长度(maxcount)即可

注意:对于素数,连续因子就是本身,且长度为1(测试点5/6)

#include<iostream>
#include<cmath>
using namespace std;
int main() {
int N, temp;
int count = 0, maxcount = 0, start = 0;
cin >> N;
for (int i = 2; i <= sqrt(N) ; i++) {
temp = N;
count = 0;
int j = i;
while (temp%j==0) {
temp /= j++;
count++;
}
if (count > maxcount) {
maxcount = count;
start = i;
}
}
if (maxcount) {
cout << maxcount << endl;
for (int i = 0; i < maxcount; i++) {
cout << start + i;
if (i != maxcount - 1)
cout << "*";
}
}
else
cout <<"1"<<endl<< N;
return 0;
}

最新文章

  1. javascript类继承的一些实验
  2. jQuery学习笔记(控件位置定位、尺寸大小的获取等)
  3. nyoj 139 我排第几个--康拓展开
  4. JAVA项目JDK版本修改
  5. CSS书写规范、顺序
  6. asp.net get server control id from javascript
  7. 驱动开发 - WDK 调试及 SVN 环境搭建
  8. 设计模式(4) -- 单例模式(Singleton)
  9. docker遇到超时
  10. adb驱动安装和使用报错笔记
  11. 4. 深入 Python 流程控制
  12. day01_雷神_Python入门
  13. Android 开发 打开默认浏览器发生崩溃
  14. webpack 的插件 DllPlugin 和 DllReferencePlugin
  15. Android属性动画:插值器与估值器
  16. 理解http请求
  17. Python操作SQLServer示例
  18. PWM----调节LED亮度
  19. HTML5 2D平台游戏开发#8指令技
  20. JavaScript 之类型转换

热门文章

  1. Unity3D脚本学习——运行时类
  2. iOS 两个页面之间的跳转
  3. SPSS-回归分析
  4. JS----贪吃蛇游戏
  5. 从后台获取的数据渲染到页面中的dom操作
  6. Latex公式示范
  7. 05_ssm基础(一)之mybatis简单使用
  8. CentOS7 安装 GitLab
  9. Emulating private methods with closures
  10. 循环流程控制&amp;方法(3)