±±¾©Ê¯ÓÍ»¯¹¤Ñ§Ôº2026ÄêÑо¿ÉúÕÐÉú½ÓÊÕµ÷¼Á¹«¸æ
²é¿´: 1557  |  »Ø¸´: 18
±¾Ìû²úÉú 5 ¸ö ³ÌÐòÇ¿Ìû £¬µã»÷ÕâÀï½øÐв鿴

holmescn

½ð³æ (ÕýʽдÊÖ)

[½»Á÷] Euler ¹¤³Ì µÚÈýÊ®ÁùÌ⣺ ÒÑÓÐ3È˲ÎÓë

Ê®½øÖÆÊý585ÊÇÒ»¸ö»ØÎÄÊý£¬²»½öÈç´Ë£¬ËüµÄ¶þ½øÖƱíʾ£º585=(1001001001)_2 Ò²ÊÇÒ»¸ö»ØÎÄÊý¡£

ÇëÕÒ³öСÓÚ100ÍòµÄËùÓÐÔÚÊ®½øÖƺͶþ½øÖƱíʾ϶¼ÊÇ»ØÎÄÊýµÄÊý£¬ÇóËûÃǵĺ͡£

[ Last edited by holmescn on 2011-7-7 at 20:33 ]
»Ø¸´´ËÂ¥

» ²ÂÄãϲ»¶

» ±¾Ö÷ÌâÏà¹Ø¼ÛÖµÌùÍÆ¼ö£¬¶ÔÄúͬÑùÓаïÖú:

ÒÑÔÄ   »Ø¸´´ËÂ¥   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

holmescn

½ð³æ (ÕýʽдÊÖ)

¡ï ¡ï ¡ï ¡ï
xzhdty(½ð±Ò+1): лл²ÎÓë 2011-07-07 22:55:02
ÓàÔó³É(½ð±Ò+3, ³ÌÐòÇ¿Ìû+1): ¹ÄÀø½»Á÷£¡ 2011-07-11 20:44:16
Python Çî¾Ù£º
CODE:
# Project Euler Problem 36
#

def checkBinaryReverse(n):
    s = bin(n)[2:]
    r = s[::-1]
    if r == s:
        return True
    return False

# 2-, 3-, 4-digits
for x in xrange(1, 10, 2):
    # 2-digits
    n = int("%d"*2 % (x, x))
    if checkBinaryReverse(n):
        print n, "=>", bin(n)[2:]

    # 3-, 4-digits
    for y in xrange(1, 10):
        # 3-digits
        n = int("%d"*3 % (x, y, x))
        if checkBinaryReverse(n):
            print n, "=>", bin(n)[2:]
        # 4-digits
        n = int("%d"*4 % (x, y, y, x))
        if checkBinaryReverse(n):
            print n, "=>", bin(n)[2:]

        # 5-, 6-digits
        for z in xrange(1, 10):
            # 5-digits
            n = int("%d"*5 % (x, y, z, y, x))
            if checkBinaryReverse(n):
                print n, "=>", bin(n)[2:]
            # 6-digits
            n = int("%d"*6 % (x, y, z, z, y, x))
            if checkBinaryReverse(n):
                print n, "=>", bin(n)[2:]

CODE:
15351 => 11101111110111
33 => 100001
313 => 100111001
32223 => 111110111011111
39993 => 1001110000111001
53235 => 1100111111110011
53835 => 1101001001001011
585 => 1001001001
585585 => 10001110111101110001
717 => 1011001101
73737 => 10010000000001001
7447 => 1110100010111
99 => 1100011

ËÙ¶ÈÌ«¿ì£¬¾Í²»ËµÁË¡£
2Â¥2011-07-07 17:13:41
ÒÑÔÄ   »Ø¸´´ËÂ¥   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

libralibra

ÖÁ×ðľ³æ (ÖøÃûдÊÖ)

æôÆï½«¾ü

¡ï ¡ï
Сľ³æ(½ð±Ò+0.5):¸ø¸öºì°ü£¬Ð»Ð»»ØÌû
dubo(½ð±Ò+1): »¶Ó­³£À´³ÌÐòÓïÑÔ°æÌÖÂÛ 2011-07-10 15:41:59
ÓàÔó³É(³ÌÐòÇ¿Ìû+1): ¹ÄÀø½»Á÷£¡ 2011-07-11 20:45:09
àÅÄØ,ÄÜÇî¾ÙµÄ»¹ÊǼòµ¥Ð©µÄ
CODE:
IDLE 2.6.6      
>>> print sum([_x for _x in xrange(1,1000001) if str(_x)==str(_x)[::-1] and str(bin(_x))[2:]==str(bin(_x))[2:][::-1]])
872187
>>>

[ Last edited by libralibra on 2011-7-7 at 17:27 ]
matlab/VB/python/c++/Javaд³ÌÐòÇë·¢QQÓʼþ:790404545@qq.com
3Â¥2011-07-07 17:25:03
ÒÑÔÄ   »Ø¸´´ËÂ¥   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

holmescn

½ð³æ (ÕýʽдÊÖ)

¡ï
dubo(½ð±Ò+1): »¶Ó­³£À´³ÌÐòÓïÑÔ°æÌÖÂÛ 2011-07-10 15:42:15
ÉÏÃæÄǸö³ÌÐòºÃÏñÉÙÒ»¸ö9009£¬ÓÖ¸ÄÁËһϡ£
CODE:
# Project Euler Problem 36
#

def checkBinaryReverse(n):
    s = bin(n)[2:]
    r = s[::-1]
    if r == s:
        return True
    return False

# odd digits
for x in xrange(1, 1000):
    n = int(str(x)+str(x)[::-1])
    if checkBinaryReverse(n):
        print n, "=>", bin(n)[2:]

# even digits
for x in xrange(1, 100):
    for y in xrange(10):
        n = int(str(x)+str(y)+str(x)[::-1])
        if checkBinaryReverse(n):
            print n, "=>", bin(n)[2:]

4Â¥2011-07-07 17:28:48
ÒÑÔÄ   »Ø¸´´ËÂ¥   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

holmescn

½ð³æ (ÕýʽдÊÖ)

¡ï
dubo(½ð±Ò+1): »¶Ó­³£À´³ÌÐòÓïÑÔ°æÌÖÂÛ 2011-07-10 15:42:26
ÒýÓûØÌû:
Originally posted by libralibra at 2011-07-07 17:25:03:
àÅÄØ,ÄÜÇî¾ÙµÄ»¹ÊǼòµ¥Ð©µÄ
[code] IDLE 2.6.6      
>>> print sum([_x for _x in xrange(1,1000001) if str(_x)==str(_x)[::-1] and str(bin(_x))[2:]==str(bin(_x))[2:][::-1]])
872187
>> ...

ÄúÕâÇî¾Ù¸üÖ±½Ó¡£

bin¾ÍÊÇ·µ»ØÒ»¸östrÁË£¬²»ÓÃÔÙת³ÉstrÁË
bin(x)[2:]¾ÍOK
5Â¥2011-07-07 17:32:38
ÒÑÔÄ   »Ø¸´´ËÂ¥   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

libralibra

ÖÁ×ðľ³æ (ÖøÃûдÊÖ)

æôÆï½«¾ü

¡ï ¡ï
Сľ³æ(½ð±Ò+0.5):¸ø¸öºì°ü£¬Ð»Ð»»ØÌû
dubo(½ð±Ò+1): »¶Ó­³£À´³ÌÐòÓïÑÔ°æÌÖÂÛ 2011-07-10 15:42:40
ÒýÓûØÌû:
Originally posted by holmescn at 2011-07-07 17:32:38:
ÄúÕâÇî¾Ù¸üÖ±½Ó¡£

bin¾ÍÊÇ·µ»ØÒ»¸östrÁË£¬²»ÓÃÔÙת³ÉstrÁË
bin(x)[2:]¾ÍOK

¹þ¹þ,ÎÒ¿´docs²»Ï¸°¡,binµÄÈ··µ»ØµÄÊÇstring,str()ÀË·ÑÁË
matlab/VB/python/c++/Javaд³ÌÐòÇë·¢QQÓʼþ:790404545@qq.com
6Â¥2011-07-07 17:58:37
ÒÑÔÄ   »Ø¸´´ËÂ¥   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

sudo

ľ³æ (ÕýʽдÊÖ)

¡ï ¡ï
Сľ³æ(½ð±Ò+0.5):¸ø¸öºì°ü£¬Ð»Ð»»ØÌû
dubo(½ð±Ò+1): »¶Ó­³£À´³ÌÐòÓïÑÔ°æÌÖÂÛ 2011-07-10 15:42:51
ÒýÓûØÌû:
Originally posted by holmescn at 2011-07-07 16:29:31:
Ê®½øÖÆÊý585ÊÇÒ»¸ö»ØÎÄÊý£¬²»½öÈç´Ë£¬ËüµÄ¶þ½øÖƱíʾ£º585=(1001001001)_2 Ò²ÊÇÒ»¸ö»ØÎÄÊý¡£

ÇëÕÒ³öСÓÚ100ÍòµÄËùÓÐÔÚÊ®½øÖƺͶþ½øÖƱíʾ϶¼ÊÇ»ØÎÄÊýµÄÊý¡£

ßÀ£¬0ºÍ1Ã÷ÏÔÒ²ÊÇÊ®½øÖƺͶþ½øÖƶ¼»ØÎĵÄÊý°É£¿
7Â¥2011-07-07 18:59:59
ÒÑÔÄ   »Ø¸´´ËÂ¥   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

sudo

ľ³æ (ÕýʽдÊÖ)

¡ï ¡ï
Сľ³æ(½ð±Ò+0.5):¸ø¸öºì°ü£¬Ð»Ð»»ØÌû
xzhdty(½ð±Ò+1): лл²ÎÓë 2011-07-07 22:55:48
ÓàÔó³É(³ÌÐòÇ¿Ìû+1): ¹ÄÀø½»Á÷£¡ 2011-07-11 20:44:43
Ìù¸ö±©Á¦µÄ£¬»¨ÉÚµÄ
CODE:
#include
#include

static const int deBruijn[32] =
{
    0, 9, 1, 10, 13, 21, 2, 29, 11, 14, 16, 18, 22, 25, 3, 30,  \
    8, 12, 20, 28, 15, 17, 24, 7, 19, 27, 23, 6, 26, 5, 4, 31   \
}; //¶þÔªÎå½×deBruijnÐòÁÐB(2,5)£º³¤¶ÈΪ5µÄ×ÓÐòÁÐÔÚÕû¸öÐòÁÐÖÐÑ­»·Î¨Ò»

int main(){
    unsigned int i;
    uint32_t v, t;
    int bits;
    int digits;

    for(i=0; i<1000000; i++){
        //Åж¨Ê®½øÖÆ»ØÎÄ
        v = i;
        t = 0;
        while(v){
            t = t*10 + v%10;
            v /= 10;
        }
        if(t!=i) continue; //ÈôÊ®½øÖƲ»ÊÇ»ØÎÄÌø»Ø

        //¼ÆËã¶þ½øÖÆÎ»Êý
        v = i | (i>>1);
        v |= v >> 2;
        v |= v >> 4;
        v |= v >> 8;
        v |= v >> 16; //°Ñ×î¸ßλµÄ1ÓÒ±ßÈ«²¿ÖÃΪ0

        bits = deBruijn[(v * 0x07C4ACDDU) >> 27] + 1; //»ñµÃ¶þ½øÖƱíʾµÄiÖµµÄλÊý£¬0x07C4ACDDÊÇÒ»¸ö32bitµÄdeBruijnÐòÁÐ

        //·´×ªÎÞ·ûºÅÕûÐÍiµÄ¶þ½øÖÆÐÎʽ£¬²¢Òƶ¯µ½ºÍÔ­À´Î»Êý¶ÔÆëµÄÐÎʽ
        v = ((i>>1) & 0x55555555) | ((i & 0x55555555) << 1);
        v = ((v>>2) & 0x33333333) | ((v & 0x33333333) << 2);
        v = ((v>>4) & 0x0F0F0F0F) | ((v & 0x0F0F0F0F) << 4);
        v = ((v>>8) & 0x00FF00FF) | ((v & 0x00FF00FF) << 8);
        v = ((v>>16) | (v<<16)) >> (32-bits);

        //Èô¶þ½øÖÆÎª»ØÎÄÔòÊä³ö
        if(i==v){
            printf("%d\n", i);
        }
    }

    return 0;
}

Êä³ö
CODE:
0
1
3
5
7
9
33
99
313
585
717
7447
9009
15351
32223
39993
53235
53835
73737
585585

Process returned 0 (0x0)   execution time : 0.031 s
Press any key to continue.

8Â¥2011-07-07 20:00:07
ÒÑÔÄ   »Ø¸´´ËÂ¥   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

sudo

ľ³æ (ÕýʽдÊÖ)

¡ï ¡ï
Сľ³æ(½ð±Ò+0.5):¸ø¸öºì°ü£¬Ð»Ð»»ØÌû
dubo(½ð±Ò+1): »¶Ó­³£À´³ÌÐòÓïÑÔ°æÌÖÂÛ 2011-07-10 15:43:00
PS£ºÉÏÃæµÄ³ÌÐò³­Ï®ÁËÁ½¶ÎÖøÃûµÄ´úÂë~¿ÉϧÅж¨Ê®½øÖÆ»ØÎĵĵط½Ì«³óªÁË~
9Â¥2011-07-07 20:11:44
ÒÑÔÄ   »Ø¸´´ËÂ¥   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

holmescn

½ð³æ (ÕýʽдÊÖ)

¡ï
dubo(½ð±Ò+1): »¶Ó­³£À´³ÌÐòÓïÑÔ°æÌÖÂÛ 2011-07-10 15:43:11
ÒýÓûØÌû:
Originally posted by sudo at 2011-07-07 20:00:07:
Ìù¸ö±©Á¦µÄ£¬»¨ÉÚµÄ

[code]
#include <stdio.h>
#include <stdint.h>

static const int deBruijn[32] =
{
    0, 9, 1, 10, 13, 21, 2, 29, 11, 14, 16, 18, 22, 25, 3, 30,  \
    8,  ...

too many magic numbers, tricky & unreadable......
10Â¥2011-07-07 20:31:00
ÒÑÔÄ   »Ø¸´´ËÂ¥   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû
Ïà¹Ø°æ¿éÌø×ª ÎÒÒª¶©ÔÄÂ¥Ö÷ holmescn µÄÖ÷Ìâ¸üÐÂ
×î¾ßÈËÆøÈÈÌûÍÆ¼ö [²é¿´È«²¿] ×÷Õß »Ø/¿´ ×îºó·¢±í
[¿¼ÑÐ] Çóµ÷¼ÁÍÆ¼ö ²ÄÁÏ 304 +15 ºÉ°üµ°hyj 2026-03-26 15/750 2026-03-28 04:13 by fmesaito
[¿¼ÑÐ] 352·Ö »¯¹¤Óë²ÄÁÏ +5 º£Äɰٴ¨Ly 2026-03-27 5/250 2026-03-28 03:39 by fmesaito
[¿¼ÑÐ] Ò»Ö¾Ô¸211ԺУ 344·Ö ¶«±±Å©Òµ´óѧÉúÎïѧѧ˶£¬Çóµ÷¼Á +5 ؼ·çѩҹ¹éÈËØ¼ 2026-03-26 8/400 2026-03-27 19:22 by ؼ·çѩҹ¹éÈËØ¼
[¿¼ÑÐ] 308Çóµ÷¼Á +6 īīĮ 2026-03-27 6/300 2026-03-27 15:20 by caszguilin
[¿¼ÑÐ] 0856µ÷¼Á +5 ÇóÇóÈÃÎÒÓÐÊé¶Á° 2026-03-26 6/300 2026-03-27 15:12 by caszguilin
[¿¼ÑÐ] 298µ÷¼Á +3 jiyingjie123 2026-03-27 3/150 2026-03-27 11:57 by wxiongid
[¿¼ÑÐ] µ÷¼ÁÍÆ¼ö +5 Ç徯714 2026-03-26 6/300 2026-03-27 11:12 by ²»³Ôô~µÄ؈
[¿¼ÑÐ] 359Çóµ÷¼Á +4 ÍõÁ˸öéª 2026-03-25 4/200 2026-03-27 08:43 by ²»³Ôô~µÄ؈
[¿¼ÑÐ] Çóµ÷¼Á£¬Ò»Ö¾Ô¸ ÄϾ©º½¿Õº½Ìì´óѧ´óѧ £¬080500²ÄÁÏ¿ÆÑ§Ó빤³Ìѧ˶ +4 @taotao 2026-03-26 5/250 2026-03-27 08:10 by hypershenger
[¿¼ÑÐ] 324Çóµ÷¼Á +8 hanamiko 2026-03-26 10/500 2026-03-27 08:06 by hypershenger
[¿¼ÑÐ] ²ÄÁϵ÷¼Á 5+4 ÏëÒªÒ»ºøÌÒ»¨Ë® 2026-03-25 10/500 2026-03-26 19:56 by ²»³Ôô~µÄ؈
[¿¼ÑÐ] ÉúÎïѧ 296 Çóµ÷¼Á +4 ¶ä¶ä- 2026-03-26 6/300 2026-03-26 19:01 by ²»³Ôô~µÄ؈
[¿¼ÑÐ] 085600 ²ÄÁÏÓ뻯¹¤ 329·ÖÇóµ÷¼Á +9 Mr. Z 2026-03-25 9/450 2026-03-26 10:36 by baoball
[¿¼ÑÐ] ÍøÂç¿Õ¼ä°²È«0839Õе÷¼Á +4 w320357296 2026-03-25 6/300 2026-03-25 17:59 by 255671
[¿¼ÑÐ] BÇø¿¼Ñе÷¼Á +4 yqdszhdap£­ 2026-03-22 5/250 2026-03-25 08:51 by baoball
[¿¼ÑÐ] 080500Çóµ÷¼Á +3 zzzzfan 2026-03-24 3/150 2026-03-24 16:38 by barlinike
[¿¼ÑÐ] Ò»Ö¾Ô¸¼ª´ó»¯Ñ§322Çóµ÷¼Á +4 17501029541 2026-03-23 6/300 2026-03-24 10:21 by ´÷Χ²±µÄСÎÃ×Ó
[¿¼ÑÐ] Ò»Ö¾Ô¸ÖØÇì´óѧ085700×ÊÔ´Óë»·¾³£¬×Ü·Ö308Çóµ÷¼Á +7 īīĮ 2026-03-23 8/400 2026-03-23 20:36 by Creta
[¿¼ÑÐ] 276Çóµ÷¼Á +3 YNRYG 2026-03-21 4/200 2026-03-23 08:31 by ×íÔÚ·çÀï
[¿¼ÑÐ] 308Çóµ÷¼Á +3 īīĮ 2026-03-21 3/150 2026-03-22 16:54 by i_cooler
ÐÅÏ¢Ìáʾ
ÇëÌî´¦ÀíÒâ¼û