CSES - Datatähti 2024 alku - Results
Submission details
Task:Monistus
Sender:Oliver2
Submission time:2023-10-31 22:43:17 +0200
Language:C++ (C++20)
Status:READY
Result:0
Feedback
groupverdictscore
#10
#20
Test results
testverdicttimegroup
#10.01 s1, 2details
#2ACCEPTED0.01 s1, 2details
#3ACCEPTED0.01 s1, 2details
#4ACCEPTED0.01 s1, 2details
#5ACCEPTED0.01 s1, 2details
#6ACCEPTED0.01 s1, 2details
#7ACCEPTED0.01 s1, 2details
#80.01 s2details
#90.01 s2details
#100.01 s2details
#110.02 s2details
#120.01 s2details
#130.01 s2details
#140.01 s2details

Code

#include <iostream>
#include <string>
#include <cstring>
using namespace std;

string inp;
char bString[1000];
char nString[9];
char rString[1000];
int indexSize;
string gen[100000];
bool dontContinue;
string res;
string build(string start, string insert, string end) {
    return start + insert + end;
}

string doCycle(string input) {
    dontContinue = true;
    //cout << "Doing cycle for: " << input << endl;
    for (int index = 0; index < int(input.size()); index++)
    {
        if (isdigit(input[index])) {
            memset(bString, 0, sizeof bString);
            memset(nString, 0, sizeof nString);
            memset(rString, 0, sizeof rString);
            dontContinue = 0;
            for (int x = 0; x < index; x++) {
                bString[x] = input[x];
            }

            indexSize = input[index] - 48;
            //cout << "number" << indexSize << "found at " << index;


            for (int j = 1; j <= indexSize; j++)
            {
                nString[j - 1] = input[index + j]; //nstring = we insert into middle

            }

            for (int k = 1; (k + index) < int(input.size()); k++) {
                rString[k - 1] = input[index + k]; //rstring we add to the end
            }
            //cout << endl << " Start of string: " << bString << endl;
            //cout << endl << " Insert into middle: " << nString << endl;
            //cout << endl << " Insert into end: " << rString << endl;
            return build(bString, nString, rString);
        }

    }
    return input;
}
int main() {
    cin >> inp;
    if (int(inp.length()) > 20) {
        return 0;
    }


    gen[0] = doCycle(inp);
    for (int i = 1; i < 1000; i++) {

        gen[i] = doCycle(gen[i - 1]);

        //cout << "curgen: " << gen[i - 1];
        if (dontContinue == true) {
            res = doCycle(gen[i]);

            break;
        }
    }
    cout << res;
}

Test details

Test 1

Group: 1, 2

Verdict:

input
987654321o987654321p

correct output
oooooooooooooooooooooooooooooo...

user output
(empty)

Test 2

Group: 1, 2

Verdict: ACCEPTED

input
1e1o1zo1r1h1y1m1b1mn

correct output
eeoozzorrhhyymmbbmmn

user output
eeoozzorrhhyymmbbmmn

Test 3

Group: 1, 2

Verdict: ACCEPTED

input
h4y21n7dz6vr1p4go1ec

correct output
hynnnnynnnndzvrppdzvrppdzvrppg...

user output
hynnnnynnnndzvrppdzvrppdzvrppg...

Test 4

Group: 1, 2

Verdict: ACCEPTED

input
bv2olah1h6o4f2mx3z1k

correct output
bvololahhhofmxmxfmxmxofmxmxfmx...

user output
bvololahhhofmxmxfmxmxofmxmxfmx...

Test 5

Group: 1, 2

Verdict: ACCEPTED

input
xewpp2f1l6a5jp1v2v1y

correct output
xewppfffllajpvvajpvvajpvvjpjpv...

user output
xewppfffllajpvvajpvvajpvvjpjpv...

Test 6

Group: 1, 2

Verdict: ACCEPTED

input
1v4z1kjm1t6vp5c1m2np

correct output
vvzkkjzkkjmttvpcmmvpcmmvpcmmnc...

user output
vvzkkjzkkjmttvpcmmvpcmmvpcmmnc...

Test 7

Group: 1, 2

Verdict: ACCEPTED

input
y2bl9cp21v7kgesxm2uv

correct output
yblblcpvvvvkgecpkkkkgecpvvvvkg...

user output
yblblcpvvvvkgecpkkkkgecpvvvvkg...

Test 8

Group: 2

Verdict:

input
987654321b987654321f987654321u...

correct output
bbbbbbbbbbbbbbbbbbbbbbbbbbbbbb...

user output
(empty)

Test 9

Group: 2

Verdict:

input
agjv4321w9dskvax5ws21r321l9n7d...

correct output
agjvwwwwwwwwwwwwwwwwdskvaxwsds...

user output
(empty)

Test 10

Group: 2

Verdict:

input
4mr1d71k432jt9sddyoy2oq7jvc1bm...

correct output
mrddmrddkkjtjtjtjtjtjtjtjtkkjt...

user output
(empty)

Test 11

Group: 2

Verdict:

input
1a1l1m1a1t1gc1yv1x1p1w1x1d1d1p...

correct output
aallmmaattggcyyvxxppwwxxddddpp...

user output
(empty)

Test 12

Group: 2

Verdict:

input
321e321b321a321r321m321f321s32...

correct output
eeeeeeeebbbbbbbbaaaaaaaarrrrrr...

user output
(empty)

Test 13

Group: 2

Verdict:

input
4321e4321l4321t4321w4321g4321c...

correct output
eeeeeeeeeeeeeeeellllllllllllll...

user output
(empty)

Test 14

Group: 2

Verdict:

input
987654321u987654321p987654321g...

correct output
uuuuuuuuuuuuuuuuuuuuuuuuuuuuuu...

user output
(empty)