結果

問題 No.1439 Let's Compare!!!!
ユーザー da_abda_ab
提出日時 2021-03-27 07:54:41
言語 Python3
(3.12.2 + numpy 1.26.4 + scipy 1.12.0)
結果
TLE  
実行時間 -
コード長 1,324 bytes
コンパイル時間 292 ms
コンパイル使用メモリ 12,672 KB
実行使用メモリ 51,224 KB
最終ジャッジ日時 2024-05-06 21:48:08
合計ジャッジ時間 10,915 ms
ジャッジサーバーID
(参考情報)
judge1 / judge3
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 501 ms
50,040 KB
testcase_01 AC 503 ms
44,020 KB
testcase_02 AC 508 ms
43,896 KB
testcase_03 AC 505 ms
44,404 KB
testcase_04 AC 501 ms
44,272 KB
testcase_05 AC 499 ms
44,400 KB
testcase_06 AC 503 ms
44,280 KB
testcase_07 AC 563 ms
44,024 KB
testcase_08 AC 574 ms
44,408 KB
testcase_09 AC 535 ms
44,148 KB
testcase_10 TLE -
testcase_11 -- -
testcase_12 -- -
testcase_13 -- -
testcase_14 -- -
testcase_15 -- -
testcase_16 -- -
testcase_17 -- -
testcase_18 -- -
権限があれば一括ダウンロードができます

ソースコード

diff #

# 1439 : Let's Compare!!!!

import numpy as np
from sys import stdin

N=int(stdin.readline())
blockSize=1000
if N<blockSize:
    blockSize=N

S=0
T=1
paddingSize=(blockSize-N%blockSize)%blockSize
padding="0"*paddingSize
N+=paddingSize
strS=padding+stdin.readline().rstrip()
strT=padding+stdin.readline().rstrip()
strST=[0]*2
strST[S]=[0]*int(np.floor(N/blockSize))
strST[T]=[0]*int(np.floor(N/blockSize))
k=0
for i in range(int(np.floor(N/blockSize))):
    strST[S][i]=strS[k:k+blockSize]
    strST[T][i]=strT[k:k+blockSize]
    k+=blockSize
Q=int(stdin.readline())

matchedMostRightBlock=-1
for _ in range(Q):
    c,x,y=stdin.readline().split()
    x=(int(x)-1)+paddingSize
    if c=='S':
        tStr=S
    else:
        tStr=T
    nThBlock=int(np.floor(x/blockSize))
    nThChar=x%blockSize
    strST[tStr][nThBlock]=strST[tStr][nThBlock][0:nThChar]+y+strST[tStr][nThBlock][nThChar+1:]
    result='='
    matchedMostRightBlock=min(nThBlock-1,matchedMostRightBlock)
    for i in range(matchedMostRightBlock+1,int(np.floor(N/blockSize))):
        intS=int(strST[S][i])
        intT=int(strST[T][i])
        if intS>intT:
            result='>'
            matchedMostRightBlock=i-1
            break
        elif intS<intT:
            matchedMostRightBlock=i-1
            result='<'
            break
    print(result)


0