如何写一个非常高效的函数, 需要计算n! (阶乘)

superwavelet 2014-03-17 11:43:21
一个题目: (2^4 表示2的4次方)

说写一个函数F, 输入这个函数的是一个正整数. 这个函数先求输入正整数 n 的阶乘: n!, 然后求n!能被2 除以多少次. 比如: 7! = 7 x 6 x 5 x 4 x 3 x 2 x 1 = 5040 = 16 x 315 = 2^4 x 315. f(7) 应该返回4, 因为 7! 可以被2^4除,但是不能被 2^5 除
题目就是让写出怎样写这样一个函数的思路

是不是用到dynamic programming? 就是先把计算过的 n! 存储起来?
...全文
474 1 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
mLee79 2014-03-18
  • 打赏
  • 举报
回复
这个不用求N!, F(N) = N/2 + N/2^2 + N/2^3 ...... 随手写大概像这样子: int slove(int N) { int r = 0; while(N) r += N /= 2; return r; }

65,186

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧