网页
资讯
视频
图片
知道
文库
贴吧
地图
采购
进入贴吧
全吧搜索
吧内搜索
搜贴
搜人
进吧
搜标签
日
一
二
三
四
五
六
签到排名:今日本吧第
个签到,
本吧因你更精彩,明天继续来努力!
本吧签到人数:0
一键签到
成为超级会员,使用一键签到
一键签到
本月漏签
0
次!
0
成为超级会员,赠送8张补签卡
如何使用?
点击日历上漏签日期,即可进行
补签
。
连续签到:
天 累计签到:
天
0
超级会员单次开通12个月以上,赠送连续签到卡3张
使用连续签到卡
03月10日
漏签
0
天
noip吧
关注:
25,164
贴子:
642,096
看贴
图片
吧主推荐
视频
游戏
13
回复贴,共
1
页
<<返回noip吧
>0< 加载中...
一道比较练基本功和思维严密性的题,可能比较水,适合水平不高的同
只看楼主
收藏
回复
武则天的御医
提高二等
6
该楼层疑似违规已被系统折叠
隐藏此楼
查看此楼
给定一个小于1000000000的正整数n,求它的约数的个数
比如说4,它有3个约数1、2、4,所以输入4之后输出的答案应该是3
笃志者
提高二等
6
该楼层疑似违规已被系统折叠
隐藏此楼
查看此楼
支持。
lzy0702
初识程序
1
该楼层疑似违规已被系统折叠
隐藏此楼
查看此楼
限制时间么?如果在Intel Core2 E8200的一个核心上限时1秒,下面的代码应该可以。
#include<iostream>
#include<cmath>
using namespace std;
int main()
{
int k=0,input,a;
cin>>input;
a=sqrt(input);
for(int i=1;i<=a;i++)
if(input%i==0)
k++;
cout<<k;
return 0;
}
lzy0702
初识程序
1
该楼层疑似违规已被系统折叠
隐藏此楼
查看此楼
我好像2了,是求约数,那最后应该输出2*k,当a*a==input时输出2*k-1
lzy0702
初识程序
1
该楼层疑似违规已被系统折叠
隐藏此楼
查看此楼
回复:5楼
应该不必要,最多3.2万次循环,枚举应该不会有问题
啸啸_飞
省选酱油
8
该楼层疑似违规已被系统折叠
隐藏此楼
查看此楼
统计不同质因数个数,存进数组里(易证20个元素的数组就远远富裕),然后每个元素都加一,乘起来就是解吧,时间复杂度O(sqrt(n))
武则天的御医
提高二等
6
该楼层疑似违规已被系统折叠
隐藏此楼
查看此楼
回复:3楼
3L的可以,不过评测机没那么好的内核,一般的CPU也可以过。你可以想想如果改成n小于等于10的18次方怎么做。
武则天的御医
提高二等
6
该楼层疑似违规已被系统折叠
隐藏此楼
查看此楼
10的14次方吧,18太大了
lzy0702
初识程序
1
该楼层疑似违规已被系统折叠
隐藏此楼
查看此楼
LZ:你说的10^9的规模,我才想的这个方法。
大规模的话可以先用筛法获得sqrt(n)以内的素数,然后分解质因数
素数或者干脆用预制表保存下来
武则天的御医
提高二等
6
该楼层疑似违规已被系统折叠
隐藏此楼
查看此楼
回复:10楼
差不多就是这样了。所以它比较水嘛
ATWRX
提高三等
5
该楼层疑似违规已被系统折叠
隐藏此楼
查看此楼
动态规划
别说我是FZL
初识程序
1
该楼层疑似违规已被系统折叠
隐藏此楼
查看此楼
其实这题是这样的。。。。。
把一个数分解质因数,比如36=2*2*3*3
那么它的所有约数都是由这些数相乘组成的
有36=2^2*3^2
则用排列组合知道36的约数为(2+1)*(2+1)——即各指数加一相乘
最后别忘了+1~~~~
o咘蓠咘亓o
提高三等
5
该楼层疑似违规已被系统折叠
隐藏此楼
查看此楼
这样应该就可以了~~~
var
i,j,n:longint;
begin
readln(n);
for i:=1 to trunc(sqrt(n)) do {到n的算术平方根即可}
if n mod i=0 then if i*i<>n then inc(j,2)
else inc(j);
writeln(j);
end.
登录百度账号
扫二维码下载贴吧客户端
下载贴吧APP
看高清直播、视频!
贴吧页面意见反馈
违规贴吧举报反馈通道
贴吧违规信息处理公示