結果

問題 No.1439 Let's Compare!!!!
ユーザー da_ab
提出日時 2021-03-27 07:54:41
言語 Python3
(3.13.1 + numpy 2.2.1 + scipy 1.14.1)
結果
TLE  
実行時間 -
コード長 1,324 bytes
コンパイル時間 137 ms
コンパイル使用メモリ 12,544 KB
実行使用メモリ 88,300 KB
最終ジャッジ日時 2024-11-29 08:06:24
合計ジャッジ時間 34,656 ms
ジャッジサーバーID
(参考情報)
judge3 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2
other AC * 8 TLE * 9
権限があれば一括ダウンロードができます

ソースコード

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