Submission #1246954

#TimeUsernameProblemLanguageResultExecution timeMemory
1246954al_reem_2010Fountain (eJOI20_fountain)C++20
0 / 100
235 ms68476 KiB
// اَللَهُمَ صَلِ عَلَىَ مُحَمَدٍ وَ آلِ مُحَمَدٍ
//#include "bits/stdc++.h"
#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
#include <cmath>
#include <map>
#include <set>
#include <queue>
#include <thread>
#include <fstream>
#include <stack>
using namespace std ;
#define int long long
#define pb push_back
#define si size()
#define fi first
#define se second
#define all(a) a.begin(),a.end()
#define applejuice ios::sync_with_stdio(false) ; cin.tie(nullptr) ; cout.tie(nullptr) ;
const int inf=1e18 ;
const int mod=1e9+7 ;
const int maxn=1e5+7 ;
const int sz=1<<17 ;
int tt=1 , e=inf ;
struct T{
    int d ;
    int c ;
} ;
int d[maxn] , c[maxn] , d2[maxn] , seg[maxn*4] ;
T an[31][maxn] ;
set<int> val ;
map<int,int> nval ;
vector<int> v[maxn] ;
void update(int x)
{
    int k=x ;
    x+=sz ;
    seg[x]=k ;
    for(x/=2 ; x>0 ; x/=2) {seg[x]=min(seg[x*2],seg[x*2+1]) ;}
}
int get(int l, int r, int lo=0, int hi=sz-1, int x=1)
{
    if(hi<l || r<lo) {return e ;}
    if(l<=lo && hi<=r) {return seg[x] ;}
    int mid=(lo+hi)/2 ;
    int segl=get(l,r,lo,mid,x*2) ;
    int segr=get(l,r,mid+1,hi,x*2+1) ;
    return min(segl,segr) ;
}
void solve()
{
    int n , q ;
    cin >> n >> q ;
    for(int i=0 ; i<n ; i++) {cin >> d[i] >> c[i] ; val.insert(d[i]) ;}
    // compression
    int k=0 ;
    for(auto i:val) {nval[i]=k ; k+=1 ;}
    for(int i=0 ; i<n ; i++) {d[i]=nval[d[i]] ; v[d[i]].pb(i) ;}
    // segment tree
    for(int i=0 ; i<maxn*4 ; i++) {seg[i]=inf ;}
    for(int i=n-1 ; i>=0 ; i--)
    {
        for(int j=0 ; j<v[i].si ; j++)
        {
            d2[v[i][j]]=get(v[i][j],n) ;
            if(d2[v[i][j]]==inf) {d2[v[i][j]]=-1 ;}
        }
        for(int j=0 ; j<v[i].si ; j++) {update(v[i][j]) ;}
    }
    // binary lefting
    for(int j=0 ; j<n ; j++) {an[0][j]={j,c[j]} ;}
    for(int j=0 ; j<n ; j++)
    {
        if(d2[j]!=-1) {an[1][j]={d2[j],c[j]+c[d2[j]]} ;}
        else {an[1][j]={-1,c[j]} ;}
    }
    // wrong is here
    for(int i=2 ; i<=30 ; i++)
    {
        for(int j=0 ; j<n ; j++)
        {
            int mid=an[i-1][j].d ;
            if(mid!=-1)
            {
                an[i][j].d=an[i-1][mid].d ;
                an[i][j].c=an[i-1][j].c+an[i-1][mid].c ;
            }
            else {an[i][j]={-1,an[i-1][j].c} ;}
        }
    }
    while(q--)
    {
        int r , v ;
        cin >> r >> v ;
        r-=1 ;
        int k=r , sum=0 ;
        // wrong is here
        for(int i=30 ; i>=0 ; i--)
        {
            if(an[i][r].d==-1) {continue ;}
            if(sum+an[i][r].c<v)
            {
                sum+=an[i][r].c ;
                r=an[i][r].d ;
                k=d2[r] ;
            }
        }
        cout << k+1 << "\n" ;
    }
}
signed main()
{
    //wrong
    applejuice ;
    //cin >> tt ;
    while(tt--) {solve() ;}
}
/*
 6 5
 4 10
 6 8
 3 5
 4 14
 10 9
 4 20
 1 25
 6 30
 5 8
 3 13
 2 8
 output :
 5
 0
 5
 4
 2
 */
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...