Submission #1140034

#TimeUsernameProblemLanguageResultExecution timeMemory
1140034PetrixFloppy (RMI20_floppy)C++20
100 / 100
57 ms3912 KiB
#include "floppy.h"
#include <bits/stdc++.h>
using namespace std;

void read_array(int sid, const vector<int>& v){
    string res = ""; int n = v.size();
    vector<int> st;
    for(int i = 0; i<n; ++i){
        while(st.size() && v[i]>v[st.back()])
            res += '0', st.pop_back();
        st.push_back(i); res += '1';
    } save_to_floppy(res);
}

vector<int> solve_queries(int sid, int n, const string& bits, const vector<int> &a, const vector<int> &b){
    int m = a.size();
    vector<vector<int>> huh(n);
    for(int i = 0; i<m; ++i)
        huh[b[i]].push_back(i);
    vector<int> ans(m), st;
    for(int i = 0, it = 0; i<n; ++i){
        while(bits[it]=='0') st.pop_back(), ++it;
        st.push_back(i); ++it;
        for(auto x : huh[i])
            ans[x] = *lower_bound(st.begin(), st.end(), a[x]);
    } return ans;
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...