CSES - Aalto Competitive Programming 2024 - wk5 - Mon - Results
Submission details
Task:Freight trains
Sender:aalto2024e_002
Submission time:2024-09-30 17:08:27 +0300
Language:C++ (C++17)
Status:READY
Result:
Test results
testverdicttime
#1ACCEPTED0.00 sdetails
#2ACCEPTED0.00 sdetails
#3ACCEPTED0.00 sdetails
#4ACCEPTED0.00 sdetails
#5ACCEPTED0.00 sdetails
#6ACCEPTED0.00 sdetails
#7ACCEPTED0.00 sdetails
#8ACCEPTED0.00 sdetails
#9ACCEPTED0.00 sdetails
#10ACCEPTED0.00 sdetails
#110.00 sdetails
#12ACCEPTED0.00 sdetails
#13ACCEPTED0.00 sdetails
#14ACCEPTED0.00 sdetails
#15ACCEPTED0.00 sdetails
#16ACCEPTED0.00 sdetails
#17ACCEPTED0.00 sdetails
#18ACCEPTED0.00 sdetails
#190.00 sdetails
#20ACCEPTED0.00 sdetails
#21ACCEPTED0.00 sdetails
#22ACCEPTED0.00 sdetails
#23ACCEPTED0.00 sdetails
#24ACCEPTED0.00 sdetails
#25ACCEPTED0.00 sdetails
#26ACCEPTED0.00 sdetails
#270.00 sdetails
#280.00 sdetails
#290.00 sdetails
#30ACCEPTED0.00 sdetails
#310.00 sdetails
#320.00 sdetails
#330.00 sdetails
#340.00 sdetails
#350.00 sdetails
#360.00 sdetails
#370.00 sdetails
#380.00 sdetails
#390.00 sdetails
#400.00 sdetails
#410.00 sdetails
#420.00 sdetails
#430.00 sdetails
#440.00 sdetails
#450.00 sdetails
#460.00 sdetails
#470.00 sdetails
#480.00 sdetails
#490.00 sdetails
#500.00 sdetails
#510.00 sdetails
#520.00 sdetails
#530.00 sdetails
#540.00 sdetails
#550.00 sdetails
#560.00 sdetails
#570.01 sdetails
#580.00 sdetails
#590.01 sdetails
#600.00 sdetails
#610.00 sdetails
#62--details
#63--details
#64--details
#65--details
#66--details
#67--details
#68--details
#69--details
#70--details
#71--details

Code

#include <bits/stdc++.h>

#define REP(i, a, b) for (int i = a; i < b; i++)

// Type Aliases for 1D and 2D vectors with initialization
#define vll(n, val) vector<long long>(n, val) // 1D vector of long longs with size n, initialized to val
#define ll long long
#define vvi(n, m, val) vector<vector<int>>(n, vector<int>(m, val))              // 2D vector of ints (n x m), initialized to val
#define vvll(n, m, val) vector<vector<long long>>(n, vector<long long>(m, val)) // 2D vector of long longs (n x m), initialized to val

using namespace std;

bool min_lexi_result_compare(const string &s, const string &t);

void print_vector(vector<int> &x)
{
    for (int v : x)
    {
        cout << v << " ";
    }
    cout << "\n";
}

void print_matrix(vector<vector<int>> &matrix)
{
    cout << "\n"
         << "----------------" << "\n";
    for (vector<int> row : matrix)
    {
        print_vector(row);
    }
    cout << "\n"
         << "----------------" << "\n";
}

int main()
{
    ios::sync_with_stdio(false);
    cin.tie(nullptr);

    int n;
    cin >> n;

    vector<string> ids(n);
    for (int i = 0; i < n; i++)
    {
        cin >> ids[i];
    }

    sort(ids.begin(), ids.end(), min_lexi_result_compare);

    for (string c : ids)
    {
        cout << c;
    }
    cout << endl;
}

bool min_lexi_result_compare(const string &s, const string &t)
{
    size_t i = 0, j = 0;
    size_t len_s = s.length(), len_t = t.length();
    size_t total_len = len_s + len_t;
    while (i + j < total_len)
    {
        char c1 = (i < len_s) ? s[i] : t[i - len_s];
        char c2 = (j < len_t) ? t[j] : s[j - len_t];
        if (c1 != c2)
            return c1 < c2;
        if (i < len_s)
            ++i;
        else
            ++j;
    }
    return false; // s + t == t + s, which is impossible since s != t
}

Test details

Test 1

Verdict: ACCEPTED

input
1
gl

correct output
gl

user output
gl

Test 2

Verdict: ACCEPTED

input
2
adedf
ff

correct output
adedfff

user output
adedfff

Test 3

Verdict: ACCEPTED

input
2
jb
lj

correct output
jblj

user output
jblj

Test 4

Verdict: ACCEPTED

input
2
qlipb
sr

correct output
qlipbsr

user output
qlipbsr

Test 5

Verdict: ACCEPTED

input
3
f
llk
onfj

correct output
fllkonfj

user output
fllkonfj

Test 6

Verdict: ACCEPTED

input
3
jaeo
mob
nk

correct output
jaeomobnk

user output
jaeomobnk

Test 7

Verdict: ACCEPTED

input
3
nemlo
psqhy
sg

correct output
nemlopsqhysg

user output
nemlopsqhysg

Test 8

Verdict: ACCEPTED

input
4
dia
eh
fbcae
gf

correct output
diaehfbcaegf

user output
diaehfbcaegf

Test 9

Verdict: ACCEPTED

input
4
c
cbfaa
egbg
fc

correct output
cbfaacegbgfc

user output
cbfaacegbgfc

Test 10

Verdict: ACCEPTED

input
4
cbc
cdd
ceed
dbeea

correct output
cbccddceeddbeea

user output
cbccddceeddbeea

Test 11

Verdict:

input
4
bfec
bgbaf
fcg
fdbbg

correct output
bfecbgbaffcgfdbbg

user output
bfecbgbaffdbbgfcg

Test 12

Verdict: ACCEPTED

input
5
aoefh
ge
imgjj
kmj
...

correct output
aoefhgeimgjjkmjmhhi

user output
aoefhgeimgjjkmjmhhi

Test 13

Verdict: ACCEPTED

input
5
bcbec
ei
fdigc
ilabd
...

correct output
bcbeceifdigcilabdlg

user output
bcbeceifdigcilabdlg

Test 14

Verdict: ACCEPTED

input
5
a
d
db
glfff
...

correct output
adbdglfffih

user output
adbdglfffih

Test 15

Verdict: ACCEPTED

input
5
ab
d
ebhin
k
...

correct output
abdebhinknab

user output
abdebhinknab

Test 16

Verdict: ACCEPTED

input
5
fasgx
o
oezws
qua
...

correct output
fasgxoezwsoquaspfd

user output
fasgxoezwsoquaspfd

Test 17

Verdict: ACCEPTED

input
5
bcggd
dcg
e
fc
...

correct output
bcggddcgefcg

user output
bcggddcgefcg

Test 18

Verdict: ACCEPTED

input
5
cmo
cx
hftbb
mil
...

correct output
cmocxhftbbmiltksr

user output
cmocxhftbbmiltksr

Test 19

Verdict:

input
5
ab
ababa
b
ca
...

correct output
ababaabbcaccb

user output
ababababccbca

Test 20

Verdict: ACCEPTED

input
5
o
rjj
sfj
ti
...

correct output
orjjsfjtiw

user output
orjjsfjtiw

Test 21

Verdict: ACCEPTED

input
5
a
aa
aaa
abbab
...

correct output
aaaaaaabbabba

user output
aaaaaaabbabba

Test 22

Verdict: ACCEPTED

input
10
aoefh
f
ge
hlmgh
...

correct output
aoefhfgehlmghimgjjjkmjmhhinmol...

user output
aoefhfgehlmghimgjjjkmjmhhinmol...

Test 23

Verdict: ACCEPTED

input
10
bcbec
cjjil
dbigk
ei
...

correct output
bcbeccjjildbigkeifdigcgfbikfil...

user output
bcbeccjjildbigkeifdigcgfbikfil...

Test 24

Verdict: ACCEPTED

input
10
a
cij
d
db
...

correct output
acijdbddhhekcgibfgglfffihkg

user output
acijdbddhhekcgibfgglfffihkg

Test 25

Verdict: ACCEPTED

input
10
ab
d
ebhin
fk
...

correct output
abdebhinfkgjdinaiodgkacknab

user output
abdebhinfkgjdinaiodgkacknab

Test 26

Verdict: ACCEPTED

input
10
buywl
fasgx
gb
jzpek
...

correct output
buywlfasgxgbjzpekoezwsoquaspfd...

user output
buywlfasgxgbjzpekoezwsoquaspfd...

Test 27

Verdict:

input
10
acg
bcggd
dcg
dede
...

correct output
acgbcggddcgdedeefcfdbbfgabbg

user output
acgbcggddcgdedeefdbbfcfgabbg

Test 28

Verdict:

input
10
cmo
cx
dpr
dtir
...

correct output
cmocxdprdtirhftbbmfmiltksrttkb...

user output
cmocxdprdtirhftbbmilmfttkbqtks...

Test 29

Verdict:

input
10
ab
ababa
abbc
b
...

correct output
ababaababbcbbbcaccbcccccc

user output
abababaabbcbbbccbcacccccc

Test 30

Verdict: ACCEPTED

input
10
dmq
gl
j
jqso
...

correct output
dmqgljjqsoorjjsfjtiulvw

user output
dmqgljjqsoorjjsfjtiulvw

Test 31

Verdict:

input
10
a
aa
aaa
abbab
...

correct output
aaaaaaabbabbabbabbabbbbbabbbbb

user output
aaaaaaabbabbbbbabbabbbababbbbb

Test 32

Verdict:

input
100
aa
acmfac
afmolcn
alllbndbli
...

correct output
aaacmfacafmolcnalllbndbliamdal...

user output
aaacmfacafmolcnalllbndbliamdal...
Truncated

Test 33

Verdict:

input
100
a
acjgj
ae
aegdb
...

correct output
aacjgjaeaegdbafcbahledfchagaja...

user output
aacjgjakbjchiaghajahledfchagae...
Truncated

Test 34

Verdict:

input
100
a
aah
abaeeaifc
abajl
...

correct output
aaahabaeeaifcabajlaehaejcdegka...

user output
aaahalejkgecaalakaeaibcaejcdeg...
Truncated

Test 35

Verdict:

input
100
a
aa
abg
abndfmmmk
...

correct output
aaaabgabndfmmmkacggjdeacogeada...

user output
aaaabndfmmmkacggjdeacogeadaehc...
Truncated

Test 36

Verdict:

input
100
afn
aic
ajrkgzldb
amcyqyh
...

correct output
afnaicajrkgzldbamcyqyhandanxhj...

user output
aicafnatfzazcbaposaxranxhjoeam...
Truncated

Test 37

Verdict:

input
100
aacdeffdd
abaacbae
abfbbff
ac
...

correct output
aacdeffddabaacbaeabfbbffacacbg...

user output
abaacbaeaacdeffddagafggdafeafb...
Truncated

Test 38

Verdict:

input
100
abnfxhutgk
ajkdoqmdqp
asxeblm
badpwpsqhn
...

correct output
abnfxhutgkajkdoqmdqpasxeblmbad...

user output
ajkdoqmdqpabnfxhutgkasxeblmbad...
Truncated

Test 39

Verdict:

input
100
a
aa
aaaaacaca
aaaabcabc
...

correct output
aaaaaaaacacaaaaabcabcaaabaaaab...

user output
aaaabbbbbbbabcbbcbabbbcbbabbca...
Truncated

Test 40

Verdict:

input
100
a
aiesfhkro
aivvkdc
ajrtj
...

correct output
aaiesfhkroaivvkdcajrtjaqfnivlb...

user output
aaiesfhkroaqfnivlaivvkdcajrtjb...
Truncated

Test 41

Verdict:

input
100
a
aa
aaaa
aaaaa
...

correct output
aaaaaaaaaaaaaaaaaaaaaaaaaaabab...

user output
aaaaaaaaaaaaaaaaaaaaaababaaaba...
Truncated

Test 42

Verdict:

input
200
a
aa
abbhjifdb
acmfac
...

correct output
aaaabbhjifdbacmfacadiadnhkaehh...

user output
aaaacmfacabbhjifdbaofmclooaoef...
Truncated

Test 43

Verdict:

input
200
a
aa
abihiahg
acjgj
...

correct output
aaaabihiahgacjgjadaeaegdbafcba...

user output
aaaakbjchiaghaljacggakhlcjakgl...
Truncated

Test 44

Verdict:

input
200
a
aah
abaeeaifc
abajl
...

correct output
aaahabaeeaifcabajlaehaejcdegka...

user output
aaahalkalhahfglkalejkgecaalaka...
Truncated

Test 45

Verdict:

input
200
a
aa
aan
abg
...

correct output
aaaaanabgabndfmmmkacggjdeacoge...

user output
aaaaanabgabndfmmmkacggjdeacoge...
Truncated

Test 46

Verdict:

input
200
ad
aegewtfc
afn
aic
...

correct output
adaegewtfcafnaicajrkgzldbamcyq...

user output
aegewtfcadatfzazcbaposaxranxhj...
Truncated

Test 47

Verdict:

input
200
a
aa
aacdeffdd
aaeceaeb
...

correct output
aaaaacdeffddaaeceaebabaacbaeab...

user output
aaaafbgdeeageccagccebfagafggda...
Truncated

Test 48

Verdict:

input
200
abnfxhutgk
aghv
ajkdoqmdqp
ajpvvalnu
...

correct output
abnfxhutgkaghvajkdoqmdqpajpvva...

user output
aghvajkdoqmdqpajpvvalnuakdmlbd...
Truncated

Test 49

Verdict:

input
200
a
aa
aaaaacaca
aaaabcabc
...

correct output
aaaaaaaacacaaaaabcabcaaaacbcaa...

user output
aaaabccbcaabbaccabccaacbcabcca...
Truncated

Test 50

Verdict:

input
200
a
abam
aiesfhkro
aivvkdc
...

correct output
aabamaiesfhkroaivvkdcajrtjakam...

user output
aabamaiesfhkroaivvkdcajrtjakam...
Truncated

Test 51

Verdict:

input
200
a
aaicd
acbjfaj
achddjj
...

correct output
aaaicdacbjfajachddjjacifadaecf...

user output
aaaicdakfdbhajdgbaighiaigdafbg...
Truncated

Test 52

Verdict:

input
1000
a
aa
aaccbkcd
aaj
...

correct output
aaaaaccbkcdaajaanabaabanikjabb...

user output
aaaaleeinoadaikoifcbjgaldgalcb...
Truncated

Test 53

Verdict:

input
1000
a
aa
aabecajcf
aabg
...

correct output
aaaaabecajcfaabgaabjllgdlkaadg...

user output
aaaahehfjailigkblaaiiggaiedcfc...
Truncated

Test 54

Verdict:

input
1000
a
aa
aablaga
aah
...

correct output
aaaaablagaaahaajaaklkjjababaee...

user output
aaaajgjaggifgajfgajfdaikcaljib...
Truncated

Test 55

Verdict:

input
1000
a
aa
aagjd
aajdlmacjn
...

correct output
aaaaagjdaajdlmacjnaakjdngdfaal...

user output
aaaalagiknbafagnccahilechcaidf...
Truncated

Test 56

Verdict:

input
1000
a
aalguz
abcce
abggxup
...

correct output
aaalguzabcceabggxupabujabxldxy...

user output
aaoaalguzaooyaoqxdkhapbvaposax...
Truncated

Test 57

Verdict:

input
1000
a
aa
aaabaaaaf
aaaeb
...

correct output
aaaaaabaaaafaaaebaabeadaabfffd...

user output
aaaaecafbeddcaeccaedbfedaeddfe...
Truncated

Test 58

Verdict:

input
1000
a
aamuthxggq
abnfxhutgk
adaumgqm
...

correct output
aaamuthxggqabnfxhutgkadaumgqma...

user output
aanfuociljaamuthxggqanqmblveao...
Truncated

Test 59

Verdict:

input
1000
a
aa
aaa
aaaa
...

correct output
aaaaaaaaaaaaaaaaaaaaaaaaaaabaa...

user output
aaaaaaaaaaaaaaaaaaaaaabccaacbc...
Truncated

Test 60

Verdict:

input
1000
a
aanmhqqnpc
ab
abam
...

correct output
aaanmhqqnpcababamabginwqvvacba...

user output
aanmaanmhqqnpcansuqraoskdirkrl...
Truncated

Test 61

Verdict:

input
1000
a
aa
aaaca
aae
...

correct output
aaaaaacaaaeaaekcaagjeahdaahhdf...

user output
aaaaghgaekifkaghccdbaggkaggbaj...
Truncated

Test 62

Verdict:

input
100000
a
aa
aaa
aaaagle
...

correct output
aaaaaaaaaagleaaabaaabiaaaaccgh...

user output
(empty)

Test 63

Verdict:

input
100000
a
aa
aaa
aaaagf
...

correct output
aaaaaaaaaagfaaaaihlblgaaaalkll...

user output
(empty)

Test 64

Verdict:

input
100000
a
aa
aaa
aaaa
...

correct output
aaaaaaaaaaaaaabkaaaaelbjbaaaaf...

user output
(empty)

Test 65

Verdict:

input
100000
a
aa
aaa
aaaa
...

correct output
aaaaaaaaaaaaaahleaaaajaaabaaab...

user output
(empty)

Test 66

Verdict:

input
100000
a
aa
aaa
aaacxrqz
...

correct output
aaaaaaaaacxrqzaaahaaaahaaaplto...

user output
(empty)

Test 67

Verdict:

input
100000
a
aa
aaa
aaaa
...

correct output
aaaaaaaaaaaaaaaaaaaaaadbaaaaaa...

user output
(empty)

Test 68

Verdict:

input
100000
a
aa
aaa
aaail
...

correct output
aaaaaaaaailaaaitehaeaaaitxaaam...

user output
(empty)

Test 69

Verdict:

input
100000
a
aa
aaa
aaaa
...

correct output
aaaaaaaaaaaaaaabghaaaabcaffaaa...

user output
(empty)

Test 70

Verdict:

input
100000
a
aa
aaa
aaaaggo
...

correct output
aaaaaaaaaaggoaaacwpgjkvaaaftbl...

user output
(empty)

Test 71

Verdict:

input
100000
a
aa
aaa
aaaa
...

correct output
aaaaaaaaaaaaaabaaaagkaaabaaabb...

user output
(empty)