CF1537E2.Erase and Extend (Hard Version)
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
This is the hard version of the problem. The only difference is the constraints on n and k . You can make hacks only if all versions of the problem are solved.
You have a string s , and you can do two types of operations on it:
- Delete the last character of the string.
- Duplicate the string: s:=s+s , where + denotes concatenation.
You can use each operation any number of times (possibly none).
Your task is to find the lexicographically smallest string of length exactly k that can be obtained by doing these operations on string s .
A string a is lexicographically smaller than a string b if and only if one of the following holds:
- a is a prefix of b , but a=b ;
- In the first position where a and b differ, the string a has a letter that appears earlier in the alphabet than the corresponding letter in b .
输入格式
The first line contains two integers n , k ( 1≤n,k≤5⋅105 ) — the length of the original string s and the length of the desired string.
The second line contains the string s , consisting of n lowercase English letters.
输出格式
Print the lexicographically smallest string of length k that can be obtained by doing the operations on string s .
输入输出样例
输入#1
8 16 dbcadabc
输出#1
dbcadabcdbcadabc
输入#2
4 5 abcd
输出#2
aaaaa
说明/提示
In the first test, it is optimal to make one duplication: "dbcadabc" → "dbcadabcdbcadabc".
In the second test it is optimal to delete the last 3 characters, then duplicate the string 3 times, then delete the last 3 characters to make the string have length k .
"abcd" → "abc" → "ab" → "a" → "aa" → "aaaa" → "aaaaaaaa" → "aaaaaaa" → "aaaaaa" → "aaaaa".