Submission #198069

#TimeUsernameProblemLanguageResultExecution timeMemory
198069heonNivelle (COCI20_nivelle)C++17
110 / 110
49 ms632 KiB
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <algorithm>
#include <cmath>
#include <vector>
#include <set>
#include <map>
#include <unordered_set>
#include <unordered_map>
#include <queue>
#include <ctime>
#include <cassert>
#include <complex>
#include <string>
#include <cstring>
#include <chrono>
#include <random>
#include <queue>
#include <bitset>
#include <stack>
#include <iomanip>
using namespace std;
#define all(x) x.begin(), x.end()
typedef vector <int> vi;
typedef pair<int,int> ii;
typedef long long ll;
typedef long double ld;
const int mod = 1e9 + 7;
const ll inf = 3e18 + 5;
int add(int a, int b) { return (a += b) < mod ? a : a - mod; }
int mul(int a, int b) { return 1LL * a * b % mod; }
int sub(int a, int b) { return (a -= b) < 0 ? a + mod : a; }
int ctz(int x) { return __builtin_ctz(x); }
int clz(int x) { return __builtin_clz(x); }

int main(){
  ios_base::sync_with_stdio(false); cin.tie(0);
  #ifdef LOCAL
  freopen("input.txt", "r", stdin);
  freopen("output.txt", "w", stdout);
  #endif

  int n;
  string s;
  cin >> n >> s;
  ld res = 2.0;
  int A = 0, B = 0;
  for(int x = 1; x <= 26; x++){
    vi has(26);
    int cnt = 0;
    int r = 0;
    for(int i = 0; i < n; i++){
      while(r < n && cnt <= x){
        if(!has[s[r] - 'a']){
          if(cnt + 1 > x) break;
          cnt++;
        }
        has[s[r++] - 'a']++;
      }
      //cout << i << " -> " << r << endl;
      if((ld) x / (ld) (r - i) < res){
        res = (ld) x / (ld) (r - i);
        A = i;
        B = r - 1;
      }
      if(has[s[i] - 'a'] == 1){
        cnt--;
      }
      has[s[i] - 'a']--;
    }
  }
  cout << A + 1 << " " << B + 1;
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...