Submission #5421609


Source Code Expand

s = input()
k = int(input())
alph = "abcdefghijklmnopqrstuvwxyz"

#典型?:辞書順最小な解の復元は後ろからDP行う
#dp[i][c] := i文字目より後ろ(i,len(s)]のsについて文字cから始まる部分文字列の通り数
dp = [[0]*len(alph) for _ in range (len(s)+1)]

#DPテーブル作成
for i in range(len(s))[::-1]:
    for ic in range(len(alph)):
        if s[i] != alph[ic]:
            dp[i][ic] = dp[i+1][ic]
        else:
            dp[i][ic] = sum(dp[i+1]) + 1
        
#Eelになる場合(ところでEelって何?)
if sum(dp[0])<k:
    print("Eel")
    exit()

#復元
i = 0
ans = ""   
while i < len(s):
    for ic in range(len(alph)):
        if dp[i][ic] < k:
            k = k - dp[i][ic]
        elif dp[i][ic] >= k:
            ans += alph[ic]
            k-=1
            while s[i] != alph[ic]:
                i += 1
            i += 1
            break
    if k <= 0:
        print(ans)
        exit()

Submission Info

Submission Time
Task G - 辞書順
User neterukun
Language PyPy3 (2.4.0)
Score 0
Code Size 991 Byte
Status TLE
Exec Time 2134 ms
Memory 509528 KB

Judge Result

Set Name All
Score / Max Score 0 / 4
Status
AC × 4
TLE × 1
Set Name Test Cases
All 00, 01, 02, 90, 91
Case Name Status Exec Time Memory
00 TLE 2134 ms 509528 KB
01 AC 284 ms 59740 KB
02 AC 160 ms 38256 KB
90 AC 161 ms 38256 KB
91 AC 160 ms 38256 KB