免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
123下一页
最近访问板块 发新帖
查看: 4827 | 回复: 22
打印 上一主题 下一主题

求个算法。 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-01-04 22:15 |只看该作者 |倒序浏览
F(n) = 1 + 2 + ,..., + n = (1+n)*n/2
求最小的n,使F(n)拥有超过500个的约数。

100的约数为 (1,2,4,5,10,20,25,50,100)

我的垃圾新手写法。
@@count=0
def yushu(num)
        (1..num).each{|i| @@count+=1  if num%i == 0}
        puts @@count
end
yushu(100)

论坛徽章:
0
2 [报告]
发表于 2009-01-04 22:17 |只看该作者
额 我理解这个题的意思是说求一个数字,它的约数应该有>=500个。

论坛徽章:
23
15-16赛季CBA联赛之吉林
日期:2017-12-21 16:39:27白羊座
日期:2014-10-27 11:14:37申猴
日期:2014-10-23 08:36:23金牛座
日期:2014-09-30 08:26:49午马
日期:2014-09-29 09:40:16射手座
日期:2014-11-25 08:56:112015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:0315-16赛季CBA联赛之山东
日期:2017-12-21 16:39:1915-16赛季CBA联赛之广东
日期:2016-01-19 13:33:372015亚冠之山东鲁能
日期:2015-10-13 09:39:062015亚冠之西悉尼流浪者
日期:2015-09-21 08:27:57
3 [报告]
发表于 2009-01-05 11:04 |只看该作者
  1. $ cat test.pl
  2. #! /usr/bin/perl

  3. use strict;
  4. use warnings;

  5. sub sum {
  6.         my $sum = shift;

  7.         $sum = (1 + $sum) * $sum / 2;

  8.         return $sum;
  9. }

  10. sub yueshu {
  11.         my $num = shift;
  12.         my $max = $num;
  13.         my $yueshu = 2;
  14.         my $i = 2;

  15.         while ( $i < $max )
  16.         {
  17.                 if ( $num % $i == 0 )
  18.                 {
  19.                         $max = $num / $i;
  20.                         if ( $i == $max )
  21.                         {
  22.                                 $yueshu ++;
  23.                         }
  24.                         else
  25.                         {
  26.                                 $yueshu += 2;
  27.                         }
  28.                 }

  29.                 $i ++;
  30.         }

  31.         return $yueshu;
  32. }

  33. my $num = 1;

  34. while( yueshu(sum($num)) < 500 )
  35. {
  36.         $num ++;
  37. }

  38. print $num;
  39. $ time test.pl
  40. 12375
  41. real    0m51.475s
  42. user    0m31.870s
  43. sys     0m0.020s
复制代码

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
4 [报告]
发表于 2009-01-05 12:08 |只看该作者

回复 #3 ly5066113 的帖子

做的运算太多了。要是顺序求因数的话,只要求到原数的平方根就行了。当然也可以先将原数分解为质因数,然后用质因数的组合得到原数的所有因数。

论坛徽章:
0
5 [报告]
发表于 2009-01-05 12:16 |只看该作者
原帖由 ly5066113 于 2009-1-5 11:04 发表
$ cat test.pl
#! /usr/bin/perl

use strict;
use warnings;

sub sum {
        my $sum = shift;

        $sum = (1 + $sum) * $sum / 2;

        return $sum;
}

sub yueshu {
        m ...


def yueshu(num)
    count=0
    arr=[]
    (1..num).each  do  |i|
        count += 1 and  arr << i   if  num%i ==0
    
        end

    return arr
end
puts yueshu(12375)

1
3
5
9
11
15
25
33
45
55
75
99
125
165
225
275
375
495
825
1125
1375
2475
4125
12375

你这个数字也没有500个约数阿。。。

[ 本帖最后由 大狗狗 于 2009-1-5 12:19 编辑 ]

论坛徽章:
0
6 [报告]
发表于 2009-01-05 12:18 |只看该作者
原帖由 MMMIX 于 2009-1-5 12:08 发表
做的运算太多了。要是顺序求因数的话,只要求到原数的平方根就行了。当然也可以先将原数分解为质因数,然后用质因数的组合得到原数的所有因数。


数学没有学好。这些概念都快忘记光了。。/

论坛徽章:
23
15-16赛季CBA联赛之吉林
日期:2017-12-21 16:39:27白羊座
日期:2014-10-27 11:14:37申猴
日期:2014-10-23 08:36:23金牛座
日期:2014-09-30 08:26:49午马
日期:2014-09-29 09:40:16射手座
日期:2014-11-25 08:56:112015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:0315-16赛季CBA联赛之山东
日期:2017-12-21 16:39:1915-16赛季CBA联赛之广东
日期:2016-01-19 13:33:372015亚冠之山东鲁能
日期:2015-10-13 09:39:062015亚冠之西悉尼流浪者
日期:2015-09-21 08:27:57
7 [报告]
发表于 2009-01-05 12:19 |只看该作者

回复 #4 MMMIX 的帖子

我这个就是算到平方根呀。

论坛徽章:
23
15-16赛季CBA联赛之吉林
日期:2017-12-21 16:39:27白羊座
日期:2014-10-27 11:14:37申猴
日期:2014-10-23 08:36:23金牛座
日期:2014-09-30 08:26:49午马
日期:2014-09-29 09:40:16射手座
日期:2014-11-25 08:56:112015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:0315-16赛季CBA联赛之山东
日期:2017-12-21 16:39:1915-16赛季CBA联赛之广东
日期:2016-01-19 13:33:372015亚冠之山东鲁能
日期:2015-10-13 09:39:062015亚冠之西悉尼流浪者
日期:2015-09-21 08:27:57
8 [报告]
发表于 2009-01-05 12:21 |只看该作者

回复 #5 大狗狗 的帖子

你题目要求的是n,拥有500个约数的是F(n)。
也就是 (1 + 12735) * 12735 / 2

论坛徽章:
3
戌狗
日期:2014-09-10 17:07:162015年辞旧岁徽章
日期:2015-03-03 16:54:15wusuopu
日期:2016-06-17 17:43:45
9 [报告]
发表于 2009-01-05 13:10 |只看该作者
原帖由 大狗狗 于 2009-1-5 12:18 发表


数学没有学好。这些概念都快忘记光了。。/

我已经忘光了。

论坛徽章:
0
10 [报告]
发表于 2009-01-05 13:24 |只看该作者
原帖由 ly5066113 于 2009-1-5 12:21 发表
你题目要求的是n,拥有500个约数的是F(n)。
也就是 (1 + 12735) * 12735 / 2



约数的个数和n 有关系吗?

F(n)=1+2+..+n=(1+n)*n/2  这个和一个数所拥有的约数个数有关系吗?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP