CSES - Datatähti 2024 alku - Results
Submission details
Task:Monistus
Sender:Oliver2
Submission time:2023-10-31 19:01:38 +0200
Language:C++ (C++20)
Status:READY
Result:0
Feedback
groupverdictscore
#10
#20
Test results
testverdicttimegroup
#10.01 s1, 2details
#20.00 s1, 2details
#30.00 s1, 2details
#40.00 s1, 2details
#50.00 s1, 2details
#60.00 s1, 2details
#70.00 s1, 2details
#80.00 s2details
#90.01 s2details
#100.01 s2details
#110.02 s2details
#120.01 s2details
#130.01 s2details
#140.01 s2details

Compiler report

input/code.cpp: In function 'std::string doCycle(std::string)':
input/code.cpp:42:41: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   42 |             for (int k = 1; (k + index) < input.size(); k++) {
      |                             ~~~~~~~~~~~~^~~~~~~~~~~~~~

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[100];
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) < 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() {
    getline(cin, inp);



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

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

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

    

    cout << "Final: " << res;
} 

Test details

Test 1

Group: 1, 2

Verdict:

input
987654321o987654321p

correct output
oooooooooooooooooooooooooooooo...

user output
Doing cycle for: 987654321o987...
Truncated

Test 2

Group: 1, 2

Verdict:

input
1e1o1zo1r1h1y1m1b1mn

correct output
eeoozzorrhhyymmbbmmn

user output
Doing cycle for: 1e1o1zo1r1h1y...
Truncated

Test 3

Group: 1, 2

Verdict:

input
h4y21n7dz6vr1p4go1ec

correct output
hynnnnynnnndzvrppdzvrppdzvrppg...

user output
Doing cycle for: h4y21n7dz6vr1...
Truncated

Test 4

Group: 1, 2

Verdict:

input
bv2olah1h6o4f2mx3z1k

correct output
bvololahhhofmxmxfmxmxofmxmxfmx...

user output
Doing cycle for: bv2olah1h6o4f...
Truncated

Test 5

Group: 1, 2

Verdict:

input
xewpp2f1l6a5jp1v2v1y

correct output
xewppfffllajpvvajpvvajpvvjpjpv...

user output
Doing cycle for: xewpp2f1l6a5j...
Truncated

Test 6

Group: 1, 2

Verdict:

input
1v4z1kjm1t6vp5c1m2np

correct output
vvzkkjzkkjmttvpcmmvpcmmvpcmmnc...

user output
Doing cycle for: 1v4z1kjm1t6vp...
Truncated

Test 7

Group: 1, 2

Verdict:

input
y2bl9cp21v7kgesxm2uv

correct output
yblblcpvvvvkgecpkkkkgecpvvvvkg...

user output
Doing cycle for: y2bl9cp21v7kg...
Truncated

Test 8

Group: 2

Verdict:

input
987654321b987654321f987654321u...

correct output
bbbbbbbbbbbbbbbbbbbbbbbbbbbbbb...

user output
Doing cycle for: 987654321b987...
Truncated

Test 9

Group: 2

Verdict:

input
agjv4321w9dskvax5ws21r321l9n7d...

correct output
agjvwwwwwwwwwwwwwwwwdskvaxwsds...

user output
Doing cycle for: agjv4321w9dsk...
Truncated

Error:
malloc(): corrupted top size

Test 10

Group: 2

Verdict:

input
4mr1d71k432jt9sddyoy2oq7jvc1bm...

correct output
mrddmrddkkjtjtjtjtjtjtjtjtkkjt...

user output
Doing cycle for: 4mr1d71k432jt...
Truncated

Error:
malloc(): corrupted top size

Test 11

Group: 2

Verdict:

input
1a1l1m1a1t1gc1yv1x1p1w1x1d1d1p...

correct output
aallmmaattggcyyvxxppwwxxddddpp...

user output
Doing cycle for: 1a1l1m1a1t1gc...
Truncated

Test 12

Group: 2

Verdict:

input
321e321b321a321r321m321f321s32...

correct output
eeeeeeeebbbbbbbbaaaaaaaarrrrrr...

user output
Doing cycle for: 321e321b321a3...
Truncated

Test 13

Group: 2

Verdict:

input
4321e4321l4321t4321w4321g4321c...

correct output
eeeeeeeeeeeeeeeellllllllllllll...

user output
Doing cycle for: 4321e4321l432...
Truncated

Test 14

Group: 2

Verdict:

input
987654321u987654321p987654321g...

correct output
uuuuuuuuuuuuuuuuuuuuuuuuuuuuuu...

user output
Doing cycle for: 987654321u987...
Truncated