24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 1040  |  回复: 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 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 329求调剂 +17 miaodesi 2026-04-02 20/1000 2026-04-05 18:33 by 蓝云思雨
[考研] 295求调剂 +8 FZAC123 2026-04-03 8/400 2026-04-05 17:46 by 蓝云思雨
[考研] 081200-11408-276学硕求调剂 +4 崔wj 2026-04-04 5/250 2026-04-05 14:06 by imissbao
[考研] 070300化学学硕311分求调剂 +10 梁富贵险中求 2026-04-04 12/600 2026-04-05 09:37 by guoweigw
[考研] 11408,335分,本科211,求调剂,可转专业 +5 鳄梨大鳄鱼 2026-04-03 5/250 2026-04-04 22:49 by chongya
[考研] 考研调剂 +6 15615482637 2026-04-04 6/300 2026-04-04 22:43 by yu221
[考研] 286求调剂 +3 草木不言 2026-04-04 3/150 2026-04-04 22:40 by lbsjt
[考研] 求调剂 +7 xzghyuj 2026-04-04 7/350 2026-04-04 22:25 by oooqiao
[考研] 材料调剂 +15 一样YWY 2026-04-01 15/750 2026-04-04 22:23 by hemengdong
[考研] 可跨专业调剂 +3 周的得地 2026-04-04 6/300 2026-04-04 22:21 by barlinike
[考研] 一志愿0817化学工程与技术,求调剂 +24 我不是只因 2026-04-02 28/1400 2026-04-04 15:15 by dongzh2009
[考研] 求调剂 +4 压力??大 2026-04-03 4/200 2026-04-03 21:36 by 啵啵啵0119
[考研] 工科341分调剂 +3 洛多罗 2026-04-03 3/150 2026-04-03 14:20 by 1753564080
[考研] 085600专硕材料与化工348分求调剂 +10 上学啦! 2026-04-01 11/550 2026-04-03 14:13 by 百灵童888
[考研] 282求调剂 不挑专业 求收留 +7 Yam. 2026-03-30 8/400 2026-04-03 14:12 by zhangdingwa
[考研] 303求调剂 +3 一色清羽 2026-04-02 4/200 2026-04-03 10:22 by 蓝云思雨
[考研] 材料340分调剂 +7 夏夜晚风_long 2026-04-02 9/450 2026-04-02 21:20 by dongzh2009
[考研] 一志愿北京科技大学085601材料工程英一数二初试总分335求调剂 +9 双马尾痞老板2 2026-04-01 9/450 2026-04-02 12:14 by oooqiao
[考研] 085602化学工程268分蹲调剂 +8 月照花林。 2026-04-01 8/400 2026-04-01 22:08 by 无际的草原
[考研] 350求调剂 +7 阿佳~ 2026-03-31 7/350 2026-04-01 16:12 by yanflower7133
信息提示
请填处理意见