/ SeriousOJ /

Record Detail

Accepted


  
# Status Time Cost Memory Cost
#1 Accepted 1ms 540.0 KiB
#2 Accepted 5ms 792.0 KiB
#3 Accepted 2ms 584.0 KiB
#4 Accepted 1ms 540.0 KiB
#5 Accepted 1ms 444.0 KiB

Code

#include <bits/stdc++.h>

#pragma GCC optimize("Ofast")
using namespace std;

void solve(int cs) {
  int n;
  cin >> n;
  string s;
  cin >> s;
  if (is_sorted(s.begin(), s.end()) || is_sorted(s.rbegin(), s.rend())) {
    cout << "0\n";
  } else {
    string t = s;
    sort(t.begin(), t.end());
    int res = 1e9;
    int cnt = 0;
    for (int i = 0; i < t.size(); i++) cnt += t[i] != s[i]; cnt = (cnt + 1) / 2;
    res = min(res, cnt);
    sort(t.rbegin(), t.rend());
    cnt = 0;
    for (int i = 0; i < t.size(); i++) cnt += t[i] != s[i]; cnt = (cnt + 1) / 2;
    cout << min(res, cnt) << "\n";
  }
}

int main() {
  ios_base::sync_with_stdio(false);
  cin.tie(NULL);
  int tc = 1;
  cin >> tc;
  for (int cs = 1; cs <= tc; cs++) {
    solve(cs);
  }
  return 0;
}

Information

Submit By
Type
Submission
Problem
P1016 Swap sort
Language
C++20 (G++ 13.2.0)
Submit At
2024-07-11 09:41:33
Judged At
2024-07-11 09:41:33
Judged By
Score
100
Total Time
5ms
Peak Memory
792.0 KiB