uva10392 Factoring Large Numbers
uva10392 Factoring Large Numbers
本文涉及的知识点是,使用线性筛选法得到素数表。
1 题目
Problem F: Factoring Large Numbers
One of the central ideas behind much cryptography is that factoring large numbers is computationally intensive. In this context one might use a 100 digit number that was a product of two 50 digit prime numbers. Even with the fastest projected computers this factorization will take hundreds of years.
You don't have those computers available, but if you are clever you can still factor fairly large numbers.
Input
The input will be a sequence of integer values, one per line, terminated by a negative number. The numbers will fit in gcc's long long int datatype. You may assume that there will be at most one factor more than 1000000.
Output
Each positive number from the input must be factored and all factors (other than 1) printed out. The factors must be printed in ascending order with 4 leading spaces preceding a left justified number, and followed by a single blank line.
Sample Input
90
1234567891
18991325453139
12745267386521023
-1
Sample Output
2
3
3
5 1234567891 3
3
13
179
271
1381
2423 30971
411522630413
2 思路
这是一个分解质因数问题,因为题目说明了数字不超过long long int表示的数,所以 这不是一个大数问题。基本的思路是首先得到素数表,再用输入的大数对素数表中的 素数依次作除法运算。
关键的地方有两个,一个是素数表的获得。这里使用了线性筛选法,把所有的合数筛去, 关键的思想在于每个合数都是被它的最小素因子筛去的,且只会被筛一次。
关键代码在于:
if (!i%prime[k]) break;
之所以可以break在于,i可以整除prime[k], 在于下一次循环要筛的数字i*prime[k+1]一定已经被prime[k]筛过了,因为素数表是按大小排列的,prime[k]比prime[k+1]小,而每个合数都是被它最小的素因子筛出去的。
第二个点在于题目中已经说明,最多有一个素因子大于1000000,所以素数表只开到1000000就可以了, 如果遍历完素数表输入的数字还没有变成1,那么,将其最终结果输出就可以了,这个结果 就是那个大于1000000的因子,否则它一定可以被1000000内的素数整除。
3 代码
#include <stdio.h>
#include <string.h> #define N 1000000
long long prime[N];
short is_prime[N]; long long get_prime (long long prime[], long long n) {
long long i, j, k;
memset (is_prime, 0, sizeof(is_prime[0])*n); j = 0;
for (i=2; i<n; i++) {
if (!is_prime[i]) prime[j++] = i;
for (k=0; k<j && i*prime[k]<n; k++) {
is_prime[ i*prime[k] ] = 1;
if (!i%prime[k]) break;
}
} return j;
} int main() {
long long n;
long long i;
long long prime_num; prime_num = get_prime (prime, N); while (scanf ("%lld", &n) != EOF) {
if (n == -1) break; for (i=0; i<prime_num && n!=1; i++) {
while (n % prime[i] == 0) {
printf (" %lld\n", prime[i]);
n /= prime[i];
}
}
if (n != 1) printf (" %lld\n", n);
printf ("\n");
} return 0;
}
4 参考
uva10392 Factoring Large Numbers的更多相关文章
- [Typescript] Improve Readability with TypeScript Numeric Separators when working with Large Numbers
		
When looking at large numbers in code (such as 1800000) it’s oftentimes difficult for the human eye ...
 - 【概率论】6-2:大数定理(The Law of Large Numbers)
		
title: [概率论]6-2:大数定理(The Law of Large Numbers) categories: - Mathematic - Probability keywords: - Ma ...
 - Law of large numbers and Central limit theorem
		
大数定律 Law of large numbers (LLN) 虽然名字是 Law,但其实是严格证明过的 Theorem weak law of large number (Khinchin's la ...
 - 中心极限定理 | central limit theorem | 大数定律 | law of large numbers
		
每个大学教材上都会提到这个定理,枯燥地给出了定义和公式,并没有解释来龙去脉,导致大多数人望而生畏,并没有理解它的美. <女士品茶>有感 待续~ 参考:怎样理解和区分中心极限定理与大数定律?
 - Markov and Chebyshev Inequalities and the Weak Law of Large Numbers
		
https://www.math.wustl.edu/~russw/f10.math493/chebyshev.pdf http://www.tkiryl.com/Probability/Chapte ...
 - 大数定律(Law of Large Numbers)
		
大数定律:每次从总体中随机抽取1个样本,这样抽取很多次后,样本的均值会趋近于总体的期望.也可以理解为:从总体中抽取容量为n的样本,样本容量n越大,样本的均值越趋近于总体的期望.当样本容量极大时,样本均 ...
 - UVA题目分类
		
题目 Volume 0. Getting Started 开始10055 - Hashmat the Brave Warrior 10071 - Back to High School Physics ...
 - HOJ题目分类
		
各种杂题,水题,模拟,包括简单数论. 1001 A+B 1002 A+B+C 1009 Fat Cat 1010 The Angle 1011 Unix ls 1012 Decoding Task 1 ...
 - UVA 10392 (13.07.28)
		
Problem F: Factoring Large Numbers One of the central ideas behind much cryptography is that factori ...
 
随机推荐
- java===java基础学习(15)---抽象,接口
			
抽象 //这就是一个抽象类 abstract class Animal { String name; int age; abstract public void cry(); } //当一个类继承的父 ...
 - 再议perl写多线程端口扫描器
			
再议perl写多线程端口扫描器 http://blog.csdn.net/sx1989827/article/details/4642179 perl写端口多线程扫描器 http://blog.csd ...
 - ES的优化布局
			
分词优化:IK Analyser Elastic Search 5.x官方提供的中文搜索并不友好,分词时经常将一句话分成很多单字,这时候可以使用IK Analyser插件进行优化,当然你在写java代 ...
 - form 表单获取所有数据 封装方法
			
function getFormJson(frm) { var o = {}; var a = $(frm).serializeArray(); $.each(a, function () { if ...
 - 微信小程序实战篇-下拉刷新与加载更多
			
下拉刷新 实现下拉刷新目前能想到的有两种方式 1. 调用系统的API,系统有提供下拉刷新的API接口 2. 监听scroll-view,自定义下拉刷新,还记得scroll-view里面有一个binds ...
 - hdu 1455(DFS+好题+经典)
			
Sticks Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Subm ...
 - 一个前端资源站 http://www.bootcss.com/
			
http://www.bootcss.com/ 里面有w3schools原版的镜像网站地址: https://www.quanzhanketang.com/ 这个网站正常版本被墙了,可以通过这个镜像访 ...
 - 【hdoj_2082】找单词
			
题目:http://acm.hdu.edu.cn/showproblem.php?pid=2082 此题采用母函数的知识求解,套用母函数模板即可: http://blog.csdn.NET/ten_s ...
 - 打印之Lodop
			
前序 前面遇到一个问题:在线打印合同.通过各方查找资料和请教他人,终于完美的解决了这个问题.其中的解决方案,可以查看:http://www.cnblogs.com/zcy-xy/p/4290436.h ...
 - 解决网页中Waiting (TTFB)数据加载过慢的问题
			
解决网页中Waiting (TTFB)数据加载过慢的问题 最近做了一个网页,在本地测试良好,数据可以得到很快的反馈,但是当部署到云端Linux上时候,就会出现加载缓慢的问题.本地测试,得到数据大概3s ...