Submission details
Task:Spin-Pop-Squeeze-Clap
Sender:aalto25c_003
Submission time:2025-09-17 21:23:16 +0300
Language:C++ (C++17)
Status:READY
Result:ACCEPTED
Test results
testverdicttime
#1ACCEPTED0.00 sdetails
#2ACCEPTED0.00 sdetails
#3ACCEPTED0.00 sdetails
#4ACCEPTED0.00 sdetails
#5ACCEPTED0.00 sdetails
#6ACCEPTED0.20 sdetails
#7ACCEPTED0.01 sdetails
#8ACCEPTED0.14 sdetails
#9ACCEPTED0.06 sdetails
#10ACCEPTED0.01 sdetails
#11ACCEPTED0.04 sdetails
#12ACCEPTED0.04 sdetails
#13ACCEPTED0.07 sdetails
#14ACCEPTED0.03 sdetails
#15ACCEPTED0.01 sdetails
#16ACCEPTED0.10 sdetails
#17ACCEPTED0.06 sdetails
#18ACCEPTED0.01 sdetails
#19ACCEPTED0.01 sdetails
#20ACCEPTED0.01 sdetails
#21ACCEPTED0.01 sdetails
#22ACCEPTED0.07 sdetails
#23ACCEPTED0.07 sdetails
#24ACCEPTED0.04 sdetails
#25ACCEPTED0.11 sdetails
#26ACCEPTED0.15 sdetails
#27ACCEPTED0.03 sdetails
#28ACCEPTED0.21 sdetails
#29ACCEPTED0.21 sdetails
#30ACCEPTED0.13 sdetails
#31ACCEPTED0.07 sdetails
#32ACCEPTED0.08 sdetails
#33ACCEPTED0.14 sdetails
#34ACCEPTED0.02 sdetails
#35ACCEPTED0.08 sdetails

Compiler report

input/code.cpp: In function 'uint64_t ff(int, std::vector<char>&, int, int, std::vector<char>&, int, int, std::vector<long unsigned int>&)':
input/code.cpp:16:38: warning: comparison of integer expressions of different signedness: '__gnu_cxx::__alloc_traits<std::allocator<long unsigned int>, long unsigned int>::value_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
   16 |   if (myCache[bbPos * aaLen + aaPos] != -1) {

Code

#include <cstdint>
#include <iostream>
#include <vector>

uint64_t ff(int aaPos, std::vector<char> &aaArr, int aaLen, int bbPos,
            std::vector<char> &bbArr, int bbLen, int spin,
            std::vector<uint64_t> &myCache) {
  if (aaPos == -1) {
    // myCache[bbPos * aaLen + aaPos] = bbPos + 1;
    return bbPos + 1;
  }
  if (bbPos == -1) {
    // myCache[bbPos * aaLen + aaPos] = aaPos + 1;
    return aaPos + 1;
  }
  if (myCache[bbPos * aaLen + aaPos] != -1) {
    // std::cout << aaPos << " " << bbPos << " "
    //           << (int)myCache[bbPos * aaLen + aaPos] << std::endl;
    return myCache[bbPos * aaLen + aaPos];
  }

  uint64_t bbMinus1 =
      ff(aaPos, aaArr, aaLen, bbPos - 1, bbArr, bbLen, spin, myCache) + 1;
  uint64_t aaMinus1 =
      ff(aaPos - 1, aaArr, aaLen, bbPos, bbArr, bbLen, spin, myCache) + 1;
  uint64_t same =
      ff(aaPos - 1, aaArr, aaLen, bbPos - 1, bbArr, bbLen, spin, myCache) +
      ((aaArr[aaPos] + spin) % 10 == bbArr[bbPos] ? 0 : 1);
  uint64_t mi = same;
  if (aaMinus1 < mi)
    mi = aaMinus1;
  if (bbMinus1 < mi)
    mi = bbMinus1;
  myCache[bbPos * aaLen + aaPos] = mi;
  return mi;
}

int main() {
  std::vector<char> aaArr;
  std::vector<char> bbArr;

  char ch = 0;
  while (std::cin.get(ch)) {
    if (ch == '\n')
      break;
    aaArr.push_back(ch - '0');
  }
  while (std::cin.get(ch)) {
    if (ch == '\n')
      break;
    bbArr.push_back(ch - '0');
  }
  //   for (int ii = 0; ii < aaArr.size(); ii++)
  //     std::cout << (int)aaArr[ii] << " ";
  //   std::cout << std::endl;
  //   for (int ii = 0; ii < bbArr.size(); ii++)
  //     std::cout << (int)bbArr[ii] << " ";
  //   std::cout << std::endl;
  int aaArrLen = aaArr.size();
  int bbArrLen = bbArr.size();
  uint64_t mi = UINT64_MAX;
  for (int spin = 0; spin < 10; spin++) {
    std::vector<uint64_t> myCache(aaArrLen * bbArrLen, -1);
    uint64_t ret = ff(aaArrLen - 1, aaArr, aaArrLen, bbArrLen - 1, bbArr,
                      bbArrLen, spin, myCache);
    if (ret + spin < mi) {
      mi = ret + spin;
    }
  }
  std::cout << mi << std::endl;
}

Test details

Test 1

Verdict: ACCEPTED

input
111222
283303

correct output
4

user output
4

Test 2

Verdict: ACCEPTED

input
123123
54545

correct output
4

user output
4

Test 3

Verdict: ACCEPTED

input
111
222

correct output
1

user output
1

Test 4

Verdict: ACCEPTED

input
999
999

correct output
0

user output
0

Test 5

Verdict: ACCEPTED

input
450
57

correct output
2

user output
2

Test 6

Verdict: ACCEPTED

input
660487647593824219489241157815...

correct output
674

user output
674

Test 7

Verdict: ACCEPTED

input
914177763170669074391500080636...

correct output
130

user output
130

Test 8

Verdict: ACCEPTED

input
011524493909266858784005756682...

correct output
681

user output
681

Test 9

Verdict: ACCEPTED

input
982597919074833788762328601290...

correct output
717

user output
717

Test 10

Verdict: ACCEPTED

input
416721106840388542143044324451...

correct output
215

user output
215

Test 11

Verdict: ACCEPTED

input
458073021573681930364262129972...

correct output
473

user output
473

Test 12

Verdict: ACCEPTED

input
917400297550473688139849165156...

correct output
699

user output
699

Test 13

Verdict: ACCEPTED

input
260181590830166131860913909960...

correct output
584

user output
584

Test 14

Verdict: ACCEPTED

input
562301238360777679361730486761...

correct output
284

user output
284

Test 15

Verdict: ACCEPTED

input
954220587915890627622301289161...

correct output
416

user output
416

Test 16

Verdict: ACCEPTED

input
067903774208751350629566447245...

correct output
442

user output
442

Test 17

Verdict: ACCEPTED

input
877893287921742180967929081003...

correct output
358

user output
358

Test 18

Verdict: ACCEPTED

input
485260574793809275253093185610...

correct output
442

user output
442

Test 19

Verdict: ACCEPTED

input
423232218340629042147624537896...

correct output
192

user output
192

Test 20

Verdict: ACCEPTED

input
983444174766143554582284201195...

correct output
83

user output
83

Test 21

Verdict: ACCEPTED

input
308023002531575464533553486397...

correct output
984

user output
984

Test 22

Verdict: ACCEPTED

input
774637064330445294039402907794...

correct output
544

user output
544

Test 23

Verdict: ACCEPTED

input
645428410366485628023288358114...

correct output
378

user output
378

Test 24

Verdict: ACCEPTED

input
175337727474341582323359837344...

correct output
695

user output
695

Test 25

Verdict: ACCEPTED

input
081836584929414654154099313187...

correct output
493

user output
493

Test 26

Verdict: ACCEPTED

input
241592066112579763355561876139...

correct output
630

user output
630

Test 27

Verdict: ACCEPTED

input
664737828830059612330669705871...

correct output
559

user output
559

Test 28

Verdict: ACCEPTED

input
230972151340592860909446321989...

correct output
696

user output
696

Test 29

Verdict: ACCEPTED

input
410946685234703970117608650309...

correct output
691

user output
691

Test 30

Verdict: ACCEPTED

input
692323212407710827747149254185...

correct output
536

user output
536

Test 31

Verdict: ACCEPTED

input
034704049619193895285878119956...

correct output
467

user output
467

Test 32

Verdict: ACCEPTED

input
336980270982636303223976539004...

correct output
543

user output
543

Test 33

Verdict: ACCEPTED

input
744311485456233719196607507429...

correct output
570

user output
570

Test 34

Verdict: ACCEPTED

input
289232763326229330631165228849...

correct output
563

user output
563

Test 35

Verdict: ACCEPTED

input
159941856600173517598637236698...

correct output
431

user output
431