結果
| 問題 | No.6 使いものにならないハッシュ | 
| コンテスト | |
| ユーザー |  | 
| 提出日時 | 2019-03-23 17:24:03 | 
| 言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 508 ms / 5,000 ms | 
| コード長 | 942 bytes | 
| コンパイル時間 | 151 ms | 
| コンパイル使用メモリ | 12,800 KB | 
| 実行使用メモリ | 11,648 KB | 
| 最終ジャッジ日時 | 2024-09-16 16:49:08 | 
| 合計ジャッジ時間 | 8,591 ms | 
| ジャッジサーバーID (参考情報) | judge6 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 32 | 
ソースコード
#!/usr/bin/env python3
# -*- coding: utf-8-*-
import math
def h(n):
    r = n%10
    while n >= 10:
        n //= 10
        r += n%10
    if r >= 10:
        r = h(r)
    return r
def isp(n):
    if n == 1:
        return False
    for i in range(2, math.floor(math.sqrt(n))+1):
        if n % i == 0:
            return False
    return True
if __name__ == '__main__':
    k = int(input())
    n = int(input())
    l = [-1,-1,-1,-1,-1,-1,-1,-1,-1,-1]
    p = []
    s = 0
    a = 0
    ap = 2
    ii = 0
    for i in range(k, n+1):
        if isp(i):
            p.append(i)
            ha = h(i)
            if l[ha] != -1:
                if s <= l[ha]:
                    d = ii - s
                    if a <= d:
                        a = d
                        ap = p[s]
                    s = l[ha]+1
            l[ha] = ii
            ii += 1
    d = len(p) - s
    if a <= d:
        a = d
        ap = p[s]
    print(ap)
            
            
            
        