24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 1041  |  回复: 5
本帖产生 2 个 程序强帖 ,点击这里进行查看

wangww2011

木虫 (著名写手)


[交流] Project Euler 49 欧拉工程 49 题

以3330为公差的等差数列1487, 4817, 8147在两个方面比较特殊:
(1)每一项都是四位数的素数
(2)任一项都可以通过其他项再排列得到

已知没有一位,两位或者三位数的三个素数能够展现出上述性质,但是还有一个由4位素数组成的数列满足上述性质。

请问把这个数列中的三个数依次连接组成的12位的数字是多少?
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

» 抢金币啦!回帖就可以得到:

查看全部散金贴

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

tieer

木虫 (正式写手)


★ ★ ★
wangww2011(金币+1):谢谢参与
xzhdty(金币+2): 欢迎讨论交流 2011-09-09 17:18:09
余泽成(程序强帖+1): 鼓励交流,欢迎常来程序语言版! 2011-09-09 23:20:12
python
CODE:
# -*- coding: cp936 -*-
#Project Euler 49 欧拉工程 49 题
#等差3330数列
#(1)每一项都是四位数的素数
#(2)任一项都可以通过其他项再排列得到
#由4位素数组成的三个数
from math import sqrt
def isprime(p):             #验证素数,素数则返回素数本身,合数则返回False
    k=1
    for i in xrange(2,int(sqrt(p))+1):
        if p%i==0:
            k=0
            return False
            break
    if k:
        return p
for x in xrange(1001,3338):   #9999-6660=3339,x为三个数中最小的,不大于此
    if isprime(x) and isprime(x+3330) and isprime(x+6660) and set(str(x))==set(str(x+3330))==set(str(x+6660)):
        print x,x+3330,x+6660

CODE:
1487 4817 8147
2969 6299 9629

[ Last edited by tieer on 2011-9-9 at 11:41 ]
2楼2011-09-09 11:35:10
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wangww2011

木虫 (著名写手)


★ ★ ★
余泽成(金币+3, 程序强帖+1): 鼓励交流! 2011-09-09 23:19:44
ben_ladeng: 2011-09-10 09:04:56
结果
CODE:
['148748178147', '296962999629']

代码
CODE:
#!/usr/bin/env python

def generatePrimes(n):#generate all prime numbers less than a given integer n, just take 0.6 seconds for the case n equals one million
    isprimes=[True]*n
    for i in range(2,n):
        if isprimes[i]:
            for j in range(2*i,n,i):
                isprimes[j] = False
    primes=[i for i in range(3,n,2) if isprimes[i]]
    primes.insert(0,2)
    return primes


def euler49():
    p1=generatePrimes(10000)
    p2=[i for i in p1 if i>1000]   
   
    res=[]
    for i in p2:
        for j in p2:
            if j>i and set(str(i))==set(str(j)):
                k=2*j-i
                if set(str(k))==set(str(i)) and k in p2:
                    res.append(''.join([str(i),str(j),str(k)]))

    return res


if __name__ == "__main__":
    print euler49()

PS:楼上怎么知道公差是3330呢?
3楼2011-09-09 12:05:16
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

tieer

木虫 (正式写手)


引用回帖:
3楼: Originally posted by wangww2011 at 2011-09-09 12:05:16:
结果
CODE:
['148748178147', '296962999629']

代码
[code]
#!/usr/bin/env python

def generatePrimes(n):#generate all prime numbers less than a given integer n, just take 0.6 seconds  ...

那公差不是题目要求的吗?
4楼2011-09-09 15:46:26
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

tieer

木虫 (正式写手)


引用回帖:
3楼: Originally posted by wangww2011 at 2011-09-09 12:05:16:
结果
CODE:
['148748178147', '296962999629']

代码
[code]
#!/usr/bin/env python

def generatePrimes(n):#generate all prime numbers less than a given integer n, just take 0.6 seconds  ...

加层公差的循环,还是只有这一个答案,呵呵,看来我是运气
5楼2011-09-09 16:36:16
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
★ ★ ★
wangww2011(金币+1):谢谢参与
xzhdty(金币+2): 欢迎讨论交流 2011-09-09 23:58:03
ben_ladeng: 2011-09-10 09:04:32
matlab
CODE:
% ans =
% 296962999629
function result = euler49()
tic;
result = '';
for i=1488:9999  
    % get current string
    a = num2str(i);
   
    % except 1487, 4817, 8147
    if strcmp(unique(a),'1478')
        continue;
    end
   
    % all permutation of current number's digits
    b = perms(a);
   
    % only check primes
    b(~isprime(str2num(b)),:) = [];
   
    % less than 3 left, jumpt over
    if size(b,1)<3
        continue;
    end
   
    % sort ascend
    b = sortrows(b);
   
    % 2nd-1st==3rd-2nd, so 1st+3rd=2*2nd
    % b(j), 1st
    for j=1:size(b,1)
        % b(k), 3rd
        for k=size(b,1):-1:j+1
            % mid, 2nd
            mid = (str2double(b(j,:))+str2double(b(k,:)))/2;
            
            % b(j,:)!=b(k,:) and 2nd is a row of b
            if ~strcmp(b(j,:),b(k,:)) && ismember(num2str(mid),b,'rows')
                result = [b(j,:),num2str(mid),b(k,:)];
                break
            end
        end
        
        % find, break
        if ~isempty(result)
            break;
        end
    end
   
    % find, break
    if ~isempty(result)
        break;
    end
end % end of i
toc;
end

6楼2011-09-09 23:33:35
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 wangww2011 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 377求调剂 +6 by.ovo 2026-04-05 6/300 2026-04-05 22:18 by dongzh2009
[考研] 求调剂 +6 chenxrlkx 2026-04-05 6/300 2026-04-05 22:05 by imissbao
[考研] 一志愿北京交通大学材料工程总分358求调剂 +4 cs0106 2026-04-04 4/200 2026-04-05 18:46 by imissbao
[考研] 求调剂 +4 chenxrlkx 2026-04-05 6/300 2026-04-05 18:38 by imissbao
[考研] 270分求调剂 +4 maxjxbsk 2026-04-01 4/200 2026-04-05 17:04 by yulian1987
[考研] 求生物学学硕调剂——364分 +7 云朵遛弯指南 2026-04-04 7/350 2026-04-04 22:49 by zhyzzh
[考研] 295求调剂 +4 A你好研究生 2026-04-04 5/250 2026-04-04 22:46 by yu221
[考研] 324求调剂 +14 想上学求调 2026-04-02 15/750 2026-04-04 20:31 by 无际的草原
[论文投稿] 求文献 5+3 ys879651$ 2026-04-02 3/150 2026-04-04 17:22 by bobvan
[考研] 0856调剂 +8 曲听筠 2026-03-30 8/400 2026-04-04 08:46 by tianyyysss
[考研] 357求调剂 +13 1050389037 2026-04-03 13/650 2026-04-03 22:27 by 无际的草原
[考研] 求调剂 +3 usbdndj 2026-04-03 3/150 2026-04-03 14:10 by dxiaoxin
[考研] 266分,一志愿电气工程,本科材料,求材料专业调剂 +9 哇呼哼呼哼 2026-04-02 9/450 2026-04-03 12:05 by 1753564080
[考研] 08工科275分求调剂 +14 AaAa7420 2026-03-31 14/700 2026-04-03 11:13 by cocolv
[考研] 生物学硕341求调剂 +4 你笑起来像云朵 2026-04-03 4/200 2026-04-03 10:32 by macy2011
[考研] 考研调剂 +3 李木子0120 2026-04-02 5/250 2026-04-02 21:45 by dongzh2009
[考研] 085602化工求调剂(331分) +9 111@127 2026-03-30 9/450 2026-04-02 20:00 by dick_runner
[论文投稿] chinese chemical letters英文版投稿求助 120+4 Yishengeryi 2026-03-30 6/300 2026-04-02 17:19 by Yishengeryi
[考研] 310分求调剂 +4 成功上岸wang 2026-04-01 4/200 2026-04-01 20:35 by liu823948201
[考研] 303分 0807学硕求调剂 +3 TYC3632 2026-04-01 3/150 2026-04-01 19:24 by lwk2004
信息提示
请填处理意见