Submission #3766133


Source Code Expand

#include <iostream>
#include <vector>
#include <string>
#include <algorithm>

using namespace std;

string S;
bool check(string str, char c)
{
  for (int i = 0; i < str.size(); i++) {
    if (str[i] != c) return false;
  }
  return true;
}

int main()
{
  cin >> S;
  string slist = S;
  sort(slist.begin(), slist.end());
  slist.erase(unique(slist.begin(), slist.end()), slist.end());

  int ans = 1100000000;
  for (auto c : slist) {
    string str = S;
    int cnt = 0;
    while (1) {
      if (check(str, c)) break;
      cnt++;
      for (int i = 0; i < str.size(); i++) {
        if (i > 0 && str[i] == c) str[i - 1] = c;
      }
      str.pop_back();
    }
    ans = min(ans, cnt);
  }
  cout << ans << endl;

  return 0;
}

Submission Info

Submission Time
Task A - Shrinking
User bombra108
Language C++14 (GCC 5.4.1)
Score 300
Code Size 773 Byte
Status AC
Exec Time 2 ms
Memory 256 KB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 300 / 300
Status
AC × 4
AC × 14
Set Name Test Cases
Sample 0_00.txt, 0_01.txt, 0_02.txt, 0_03.txt
All 0_00.txt, 0_01.txt, 0_02.txt, 0_03.txt, 1_00.txt, 1_01.txt, 1_02.txt, 1_03.txt, 1_04.txt, 1_05.txt, 1_06.txt, 1_07.txt, 1_08.txt, 1_09.txt
Case Name Status Exec Time Memory
0_00.txt AC 1 ms 256 KB
0_01.txt AC 1 ms 256 KB
0_02.txt AC 1 ms 256 KB
0_03.txt AC 1 ms 256 KB
1_00.txt AC 1 ms 256 KB
1_01.txt AC 1 ms 256 KB
1_02.txt AC 1 ms 256 KB
1_03.txt AC 1 ms 256 KB
1_04.txt AC 1 ms 256 KB
1_05.txt AC 1 ms 256 KB
1_06.txt AC 1 ms 256 KB
1_07.txt AC 1 ms 256 KB
1_08.txt AC 2 ms 256 KB
1_09.txt AC 2 ms 256 KB