結果

問題 No.910 素数部分列
ユーザー stng
提出日時 2022-08-13 11:37:42
言語 PyPy3
(7.3.15)
結果
WA  
実行時間 -
コード長 1,397 bytes
コンパイル時間 269 ms
コンパイル使用メモリ 82,460 KB
実行使用メモリ 131,140 KB
最終ジャッジ日時 2024-09-24 15:55:42
合計ジャッジ時間 6,155 ms
ジャッジサーバーID
(参考情報)
judge1 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 13 WA * 37
権限があれば一括ダウンロードができます

ソースコード

diff #

import math
def sieve_of_eratosthenes(n):
    prime = [True for i in range(n+1)]
    prime[0] = False
    prime[1] = False

    sqrt_n = math.ceil(math.sqrt(n))
    for i in range(2, sqrt_n):
        if prime[i]:
            for j in range(2*i, n+1, i):
                prime[j] = False

    return prime

#pri = sieve_of_eratosthenes(1000)
#print(pri[991],pri[200])
n = int(input())
s = input()
li = []
ans = 0
for i in range(n):
    if s[i] != "1" and s[i] != "9":
        ans += 1
    else:
        li.append(s[i])


idx = set()
cnt = 0
flag = False
for i in range(len(li)):
    if flag == False:
        if li[i] == "1":
            flag = True
            tmp = i
    else:
        if li[i] == "9":
            flag = False
            idx.add(tmp)
            idx.add(i)
            ans += 1

li2 = []
for i in range(len(li)):
    if i not in idx:
        li2.append(li[i])


idx = set()
flag = False
for i in range(len(li2)):
    if flag == False:
        if li2[i] == "1":
            flag = True
            tmp = i
    else:
        if li2[i] == "1":
            flag = False
            idx.add(tmp)
            idx.add(i)
            ans += 1

li3 = []
f = 0
for i in range(len(li2)):
    if i not in idx:
        if li2[i] == "9":
            f += 1
        else:
            if f >= 2:
                ans += 1
                break
            else:
                break
print(ans)
0