SAS中文论坛

 找回密码
 立即注册

扫一扫,访问微社区

查看: 664|回复: 3
打印 上一主题 下一主题

找质数(素数)

[复制链接]

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
楼主
 楼主| 发表于 2010-1-12 09:59:56 | 只看该作者

找质数(素数)

最近天气比较冷,人气也不旺,现在弄个小题目热热身:
寻找质数(素数)集合,一直到最小的两质数之差为62.
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
沙发
 楼主| 发表于 2010-1-13 05:19:33 | 只看该作者

Re: 找质数(素数)

用C,Matlab等都很好编,用SAS不会,现在只会用SAS读读数据整理整理再means,glm这种分析一下。。。期待高手解答~~
回复 支持 反对

使用道具 举报

0

主题

0

帖子

2

积分

新手上路

Rank: 1

积分
2
板凳
发表于 2010-1-13 09:16:24 | 只看该作者

Re: 找质数(素数)

不明白呀,跟集合有什么关系?
是由小到大的找质数,找到间隔大于等于62?
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
地板
 楼主| 发表于 2010-1-13 11:55:08 | 只看该作者

Re: 找质数(素数)

Does this work? <!-- s:-) --><img src="{SMILIES_PATH}/icon_smile.gif" alt=":-)" title="Smile" /><!-- s:-) -->

[code:2eemt1d1]data primes(keep = prime);
  retain difference testOn previousPrime;

  prime = 2;
  output;

  difference = 0;
  testOn = 3;

  do while (difference &lt;= 62);
    isPrime = 1;

    do divisor = 3 to int(sqrt(testOn)) by 2;
      if mod(testOn, divisor) = 0 then do;
        isPrime = 0;
        leave;
      end;
    end;
   
    if isPrime = 1 then do;
      prime = testOn;
      difference = prime - previousPrime;
      previousPrime = Prime;
      output;
    end;

    testOn = testOn + 2;
  end;
run;[/code:2eemt1d1]
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|小黑屋|手机版|Archiver|SAS中文论坛  

GMT+8, 2026-2-6 08:04 , Processed in 0.101310 second(s), 21 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表