(笔试题)质数因子Prime Factor
题目:
Given any positive integer N, you are supposed to find all of its prime factors, and write them in the format N = p1^k1 * p2^k2 *...*pm^km.
输入描述:
Each input file contains one test case which gives a positive integer N in the range of long int.
输出描述:
Factor N in the format N = p1^k1 * p2^k2 *...*pm^km, where pi's are prime factors of N in increasing order, and the exponent ki is the number of pi -- hence when there is only one pi, ki is 1 and must NOT be printed out.
输入例子:
97532468
输出例子:
97532468=2^2*11*17*101*1291
思路:
本题是正整数n的质因子分解问题。n分为3种情况:
1、n=1,特殊数据,既不是质数也不能分解,直接按指定格式输出即可。
2、n是素数,不用分解,直接按指定格式输出即可。要判别n是否为质数,有多种方法,对于本题而言,最简单的方法是使用试商法。因为即使对于n=2147483647=2^31-1范围内的整数,用试商法效率也是很高的,具体参见下面给出的代码。
3、n是大于1的非质数,这正是本题要完成的工作。可以从最小的素数2开始,依次用2,3,4,5,...,sqrt(n)对n进行分解。因为当对2进行分解时,后面关于2的倍数的其他数字也就不能被n整除了,因此也就只对质数的进行计算,记得每次结束某个数字的因式分解之后,更新一下sqrt(n)。
当然,可以考虑采用筛法,事先把一定范围内的质数全部筛选出来,存入数组,然后只用这些质数去分解n,效率会相应提高很多。
(4)本题还有一点需要注意,即打印的格式。
代码:
在线测试:http://www.nowcoder.com/questionTerminal/ea8f62f661554099baed9baa471c6883?orderByHotValue=1&done=0&pos=6&onlyReference=false
AC代码:
#include<iostream>
#include<math.h> using namespace std; bool isPrime(int n){
if(n<2)
return false;
int k=int(sqrt(n+0.0));
for(int i=2;i<=k;i++){
if(n%i==0)
return false;
}
return true;
} void PrimeFactor(int n){
cout<<n<<"=";
if(n==1){
cout<<n<<endl;
return;
}
if(isPrime(n)){
cout<<n<<endl;
return;
} int k=int(sqrt(n+0.0));
int exp=0;
bool first=true; for(int i=2;i<=k;i++){
exp=0;
if(n%i==0){
while(n%i==0){
n=n/i;
++exp;
}
if(first){
if(exp>=2) cout<<i<<"^"<<exp;
else cout<<i;
first=false;
}
else{
if(exp>=2) cout<<"*"<<i<<"^"<<exp;
else cout<<"*"<<i;
}
k=int(sqrt(n+0.0));
}
} if(n>1) cout<<"*"<<n;
cout<<endl;
} int main(){
int n;
while(cin>>n){
PrimeFactor(n);
}
return 0;
}
(笔试题)质数因子Prime Factor的更多相关文章
- 杭电 2136 Largest prime factor(最大素数因子的位置)
		Largest prime factor Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Oth ... 
- 剑指Offer——美团内推+校招笔试题+知识点总结
		剑指Offer--美团内推+校招笔试题+知识点总结 前言 美团9.9内推笔试.9.11校招笔试,反正就是各种虐,笔试内容如下: 知识点:图的遍历(DFS.BFS).进程间通信.二叉查找树节点的删除及中 ... 
- C   2010年笔试题
		1 有一个函数, 写一段程序,输入的值,输出的值. #include <stdio.h> void main() { int x,y; printf("输入x:"); ... 
- 嵌入式Linux C笔试题积累(转)
		http://blog.csdn.net/h_armony/article/details/6764811 1. 嵌入式系统中断服务子程序(ISR) 中断是嵌入式系统中重要的组成部分,这导致了很 ... 
- Problem 3: Largest prime factor
		The prime factors of 13195 are 5, 7, 13 and 29. What is the largest prime factor of the number 60085 ... 
- R语言学习——欧拉计划(3)Largest prime factor 求最大质因数
		The prime factors of 13195 are 5, 7, 13 and 29. What is the largest prime factor of the number 60085 ... 
- HDU 2136 素数打表+求质数因子
		Largest prime factor Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Oth ... 
- [暑假集训--数论]hdu2136 Largest prime factor
		Everybody knows any number can be combined by the prime number. Now, your task is telling me what po ... 
- The largest prime factor(最大质因数)
		1. 问题: The prime factors of 13195 are 5, 7, 13 and 29.What is the largest prime factor of the number ... 
随机推荐
- 在phpWeChat中如何定义一个授权登录(获取昵称)的链接
			在phpWeChat中如何定义一个授权登录(获取昵称)的超链接?使其点击后出现如下效果? 由于集成了这个功能,其实这个需要是很简单的. 假如您想在授权后跳转到http://www.baidu.com/ ... 
- 切换java版本
			First, clean your project: Project > Clean If that doesn't fix things... Second check your projec ... 
- 2017四川省赛D题《Dynamic Graph》
			题意:给出一个n个点m条边的有向无环图(DAG),初始的时候所有的点都为白色.然后有Q次操作,每次操作要把一个点的颜色改变,白色<->黑色,对于每次操作,输出满足下列点对<u,v&g ... 
- [Codeforces #514] Tutorial
			Link: Codeforces #514 传送门 很简单的一场比赛打崩了也是菜得令人无话可说…… D: 一眼二分,发现对于固定的半径和点,能包含该点的圆的圆心一定在一个区间内,求出区间判断即可 此题 ... 
- 尝试用Gearman实现分布式处理(PHP)[转]
			本文需要你已对Gearman有个大致了解. 顺便再推荐两篇参考文章http://hi.baidu.com/thinkinginlamp/blog/item/ff49972b9e7378f3e6cd40 ... 
- PHP -- 8个必备的PHP功能开发
			原文出处:http://www.codeceo.com/8-php-functions.html 做过PHP开发的程序员应该清楚,PHP中有很多内置的功能,掌握了它们,可以帮助你在做PHP开发时更加得 ... 
- Codeforces Beta Round #6 (Div. 2 Only) D. Lizards and Basements 2 dfs
			D. Lizards and Basements 2 题目连接: http://codeforces.com/contest/6/problem/D Description This is simpl ... 
- hdu 5206 Four Inages Strategy 判断是否是正方形
			Four Inages Strategy Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem. ... 
- Media Queries之Respond.js
			一.stackoverflow上面对css3-mediaqueries.js与respond.js的比较 css3-mediaqueries.js Pros Supports min, max and ... 
- 微信小程序背景音频播放分享功能
			如果正常背景音频播放的话,只能跳转到自己对应的微信小程序,无法分享朋友圈,我们需要设置分享朋友圈,需要调用一个API 音频背景播放 注意:背景播放在锁屏后播放只支持IOS端,安卓端虽然可以播放,但是锁 ... 
