1015 Reversible Primes

A reversible prime in any number system is a prime whose “reverse” in that number system is also a prime. For example in the decimal system 73 is a reversible prime because its reverse 37 is also a prime.

Now given any two positive integers N (<10​5​) and D (1

Input Specification:
The input file consists of several test cases. Each case occupies a line which contains two integers N and D. The input is finished by a negative N.

Output Specification:
For each test case, print in one line Yes if N is a reversible prime with radix D, or No if not.

Sample Input:
73 10
23 2
23 10
-2
Sample Output:
Yes
Yes
No

题意:给出来两个数n和b,如果n是一个素数,并且在b进制下反转之后还是一个素数,那这个数n就是一个可逆素数,输出Yes,否则输出No。

解题思路:
构造2个函数,一个用来判断n是否为素数,一个用来将n在b进制下反转并转回十进制。

import math
def isprime(n):
    if n <= 3:
        return n > 1
    if n%6 != 1 and n%6 != 5:
        return False
    for i in range(5,int(math.sqrt(n)),6):
        if n%i==0 or n%(i+2)==0:
            return False
    return True

def reverse(n, b):
    l = []
    while n >= b:
        a = n%b
        n = n//b
        l.append(a)
    l.append(n)
    l = l[::-1]
    s = 0
    for i in range(len(l)):
        s += l[i]*(b**i)
    return s
     
while 1:
    l = list(map(int,input().split()))
    if l[0]<0:
        break
    if isprime(l[0]) and isprime(reverse(l[0],l[1])):
        print('Yes')
    else:
        print('No') 

1015 Reversible Primes_第1张图片

你可能感兴趣的:(Python)