CSES - Datatähti 2024 alku - Results
Submission details
Task:Monistus
Sender:Oliver2
Submission time:2023-11-01 17:55:40 +0200
Language:C++ (C++20)
Status:READY
Result:0
Feedback
groupverdictscore
#10
#20
Test results
testverdicttimegroup
#10.00 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.00 s2details
#100.00 s2details
#110.00 s2details
#120.00 s2details
#130.00 s2details
#140.00 s2details

Compiler report

input/code.cpp: In function 'int main()':
input/code.cpp:46:35: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   46 |                 for (int j = 0; j < generation.length(); j++) tem[j] = generation[j];
      |                                 ~~^~~~~~~~~~~~~~~~~~~~~
input/code.cpp:49:26: warning: suggest parentheses around assignment used as truth value [-Wparentheses]
   49 |                 if (done = true) {
      |                     ~~~~~^~~~~~

Code

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

char bWord[100], mWord[100], eWord[100], input[20], tem[100];
string generation;
bool done;
int findDigit(const char inp[20]) {
	for (int i = 0; i < 20; i++) 
	{ 
		if (isdigit(inp[i])) return i; 
	}
	return -1;
}
string runCycle(const char inp[20])
{
	int numberIndex = findDigit(inp);
	if (numberIndex == -1) {
		done = true;
		return inp;
	}
	
	for (int i = 0; i < 20; i++) {
		if (i < numberIndex) 
		{
			bWord[i] = inp[i];
		}
		else if (i < (numberIndex + inp[numberIndex] - 48)) {
			mWord[i - numberIndex] = inp[i + 1];
			eWord[i - numberIndex] = inp[i + 1];
		}
		else
		{
			eWord[i - numberIndex] = inp[i + 1];
		}
	}
	//cout << "Beginning word: " << bWord << endl << "Insert Word: " << mWord << endl << "Ending word: " << eWord << endl;
	return string(bWord) + string(mWord) + string(eWord);
}
int main() {
	cin >> input;
	
	generation = runCycle(input);
	for (int i = 0; i < 50; i++) 
	{
		for (int j = 0; j < generation.length(); j++) tem[j] = generation[j];
		
		generation = runCycle(tem);
		if (done = true) {
			cout << generation;
			return 0;
		}
	}
	cout << generation;
	return 0;
}

Test details

Test 1

Group: 1, 2

Verdict:

input
987654321o987654321p

correct output
oooooooooooooooooooooooooooooo...

user output
7654321oo7654321o87654321o987

Test 2

Group: 1, 2

Verdict:

input
1e1o1zo1r1h1y1m1b1mn

correct output
eeoozzorrhhyymmbbmmn

user output
eeoo1zo1r1h1y1m1b1m

Test 3

Group: 1, 2

Verdict:

input
h4y21n7dz6vr1p4go1ec

correct output
hynnnnynnnndzvrppdzvrppdzvrppg...

user output
hy1n1n1ny21n7dz6vr1p4go1

Test 4

Group: 1, 2

Verdict:

input
bv2olah1h6o4f2mx3z1k

correct output
bvololahhhofmxmxfmxmxofmxmxfmx...

user output
bvololahhlh6o4f2mx3z1

Test 5

Group: 1, 2

Verdict:

input
xewpp2f1l6a5jp1v2v1y

correct output
xewppfffllajpvvajpvvajpvvjpjpv...

user output
xewppff1f1l6a5jp1v2v1

Test 6

Group: 1, 2

Verdict:

input
1v4z1kjm1t6vp5c1m2np

correct output
vvzkkjzkkjmttvpcmmvpcmmvpcmmnc...

user output
vvz1kjz1kjm1t6vp5c1m2n

Test 7

Group: 1, 2

Verdict:

input
y2bl9cp21v7kgesxm2uv

correct output
yblblcpvvvvkgecpkkkkgecpvvvvkg...

user output
yblblcp21v7kgecp21v7kgesxm2u

Test 8

Group: 2

Verdict:

input
987654321b987654321f987654321u...

correct output
bbbbbbbbbbbbbbbbbbbbbbbbbbbbbb...

user output
7654321bb7654321b87654321b987

Test 9

Group: 2

Verdict:

input
agjv4321w9dskvax5ws21r321l9n7d...

correct output
agjvwwwwwwwwwwwwwwwwdskvaxwsds...

user output
agjv21ww21w321w9dskvax5w

Test 10

Group: 2

Verdict:

input
4mr1d71k432jt9sddyoy2oq7jvc1bm...

correct output
mrddmrddkkjtjtjtjtjtjtjtjtkkjt...

user output
mrdr1ddmr1d71k432jt9sddy

Test 11

Group: 2

Verdict:

input
1a1l1m1a1t1gc1yv1x1p1w1x1d1d1p...

correct output
aallmmaattggcyyvxxppwwxxddddpp...

user output
aall1m1a1t1gc1yv1x1

Test 12

Group: 2

Verdict:

input
321e321b321a321r321m321f321s32...

correct output
eeeeeeeebbbbbbbbaaaaaaaarrrrrr...

user output
1ee1e21e321b321a321r321

Test 13

Group: 2

Verdict:

input
4321e4321l4321t4321w4321g4321c...

correct output
eeeeeeeeeeeeeeeellllllllllllll...

user output
21ee21e321e4321l4321t432

Test 14

Group: 2

Verdict:

input
987654321u987654321p987654321g...

correct output
uuuuuuuuuuuuuuuuuuuuuuuuuuuuuu...

user output
7654321uu7654321u87654321u987