[编程题]质数因子 C递归解法

质数因子

http://www.nowcoder.com/questionTerminal/196534628ca6490ebce2e336b47b3607

题目描述
功能:输入一个正整数,按照从小到大的顺序输出它的所有质数的因子(如180的质数因子为2 2 3 3 5 )

最后一个数后面也要有空格

详细描述:
函数接口说明:

public String getResult(long ulDataInput)

输入参数:
long ulDataInput:输入的正整数

返回值:
String

输入描述:
输入一个long型整数

输出描述:
按照从小到大的顺序输出它的所有质数的因子,以空格隔开。最后一个数后面也要有空格。

#include "stdio.h"

int main()
{
    long int n;

    scanf("%ld", &n);
    for (int i=2; i<=n; i++) {
        while (n%i == 0) {
            printf("%d ", i);
            n /= i;
        }
    }
}
全部评论
超时,不可取
1 回复 分享
发布于 2021-03-25 17:25
代码很好,思路很棒,但就是超时了
1 回复 分享
发布于 2021-06-01 08:23
牛,我居然还每次都判断了一下除数是不是质数,憨憨了。
12 回复 分享
发布于 2020-04-27 16:49
这答案过不了
12 回复 分享
发布于 2020-12-03 17:22
帮大佬改进了,3ms通过。。。,我把改进代码放在了本题题解中了。
8 回复 分享
发布于 2021-07-12 21:00
这段代码写的很精妙,代码少,好理解,但是超时了,解决超时问题,其实循环里面i<=sqrt(n)就可以了,又为了避免引入math.h头文件,可以写成i*i<=n。 #include "stdio.h" int main() { long int n; scanf("%ld", &n); for (int i=2; i*i<=n; i++) { while (n%i == 0) { printf("%d ", i); n /= i; } } if(n!=1) printf("%d", n); }
6 回复 分享
发布于 2022-06-19 11:18
因为2运行过后的到4的时候就不可能余数为0 其他的类推
3 回复 分享
发布于 2021-03-28 14:54
质因数的范围太大了,范围可以定义为质因数*质因数<=正整数,例如121,质因数就是11 11
2 回复 分享
发布于 2021-01-25 15:56
会超时,加了一个对大质数本身的判断: #include <stdio.h> #include <math.h> int main() { long int n,b; scanf("%ld", &n); for (int i=2; i<=n; i++) { if(i>sqrt(n)+1){ i=n; } while (n%i == 0) { printf("%d ", i); n /= i; } } }</math.h></stdio.h>
2 回复 分享
发布于 2022-03-15 16:30
你的超时了,优化的代码送给你。 scanf("%ld", &n); for (int i=2; i*i<=n; i++) { while (n%i == 0) { printf("%d ", i); n /= i; } } if (n != 1) printf("%d ", n);
点赞 回复 分享
发布于 2023-02-23 15:03 北京
这个代码感觉很不错
点赞 回复 分享
发布于 2020-02-27 03:23
超时怎么办,比如一个数是质数循环就要质数遍会超时
点赞 回复 分享
发布于 2020-11-25 11:09
2971215073 ?
点赞 回复 分享
发布于 2021-02-08 07:37
哪句代码保证是质数了?i++加到4不是翻车了?
点赞 回复 分享
发布于 2021-02-08 11:52
这个代码就很巧妙了,牛
点赞 回复 分享
发布于 2021-03-19 00:50
超时了啊
点赞 回复 分享
发布于 2021-03-20 11:56
为啥不需要判断i是不是质数呢
点赞 回复 分享
发布于 2021-03-26 21:39
chaoshi
点赞 回复 分享
发布于 2021-03-31 10:28
189765301178902213这个长整数测试一下看看
点赞 回复 分享
发布于 2021-04-04 16:32
超时了啊,不行哦
点赞 回复 分享
发布于 2021-04-05 17:10

相关推荐

蔡徐kun:还行,早挂晚挂都是挂。早点挂进池子等别人捞你
点赞 评论 收藏
分享
评论
138
18
分享

创作者周榜

更多
正在热议
更多
# 听劝,这个简历怎么改 #
14081次浏览 182人参与
# 面试被问“你的缺点是什么?”怎么答 #
6309次浏览 98人参与
# 水滴春招 #
16260次浏览 346人参与
# 入职第四天,心情怎么样 #
11280次浏览 63人参与
# 租房找室友 #
8005次浏览 53人参与
# 读研or工作,哪个性价比更高? #
26151次浏览 356人参与
# 职场新人生存指南 #
199185次浏览 5509人参与
# 参加完秋招的机械人,还参加春招吗? #
26960次浏览 276人参与
# 文科生还参加今年的春招吗 #
4101次浏览 31人参与
# 简历无回复,你会继续海投还是优化再投? #
48619次浏览 561人参与
# 你见过最离谱的招聘要求是什么? #
144708次浏览 829人参与
# 如果重来一次你还会读研吗 #
155714次浏览 1706人参与
# 机械人选offer,最看重什么? #
69076次浏览 449人参与
# 选择和努力,哪个更重要? #
44269次浏览 492人参与
# 如果再来一次,你还会学硬件吗 #
103643次浏览 1245人参与
# 如果你有一天可以担任公司的CEO,你会做哪三件事? #
20519次浏览 413人参与
# 招聘要求与实际实习内容不符怎么办 #
46703次浏览 494人参与
# 22届毕业,是读研还是拿外包offer先苟着 #
4652次浏览 27人参与
# 你们的毕业论文什么进度了 #
901211次浏览 8960人参与
# 软开人,你觉得应届生多少薪资才算合理? #
81371次浏览 496人参与
# 国企还是互联网,你怎么选? #
109189次浏览 853人参与
牛客网
牛客企业服务