# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
797907 | vjudge1 | Worst Reporter 3 (JOI18_worst_reporter3) | C++17 | 448 ms | 11240 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
using namespace std;
#define TL ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
#define rall(s) s.rbegin(),s.rend()
#define all(s) s.begin(),s.end()
#define pb push_back
#define fi first
#define se second
#define ll long long
#define ld long double
#define YES cout<<"YES\n"
#define Yes cout<<"Yes\n"
#define yes cout<<"yes\n"
#define NO cout<<"NO\n"
#define No cout<<"No\n"
#define no cout<<"no\n"
const int N = 5e5 + 9 , mod = 1e9 + 7;
ll d[N] = {} , a[N] = {}, dp[N] = {}, b[N] , c[N];
void solve(){
ll q , i , j , m ,n, z , s = 0, f, l , r , k , x , y , mn = 1e18 , mx = -1;
cin>>n>>q;
for(i = 1; i <= n; i++)
cin>>a[i];
c[0] = 1 ;
for(i = 1; i <= n; i++){
if(a[i] <= a[i - 1])
c[i] = c[i - 1];
else
c[i] = ((a[i]) / c[i - 1] + (((a[i]) % c[i - 1]) != 0)) * c[i - 1];
//cout<<c[i]<<" ";
}
while(q--){
cin>>k>>x>>y;
l = 0 , r = n;
while(l != r){
m = (l + r + 1) / 2;
if((k / c[m]) * c[m] + (-m) >= x) l = m;
else r = m - 1;
}
f = l;
l = 0, r= n;
while(l != r){
m = (l + r) / 2;
if((k / c[m]) * c[m] + (-m) <= y) r = m;
else l = m + 1;
}
k = (((k / c[f]) * c[f] + (-f) >= x) && ((k / c[l]) * c[l] + (-l) <=y));
if(k == 1)
cout<<max(0ll ,f - l + 1)<<"\n";
else
cout<<0<<"\n";
}
}
int main(){
TL;
/*
#ifndef ONLINE_JUDGE
freopen("input.txt", "r", stdin);
freopen("output.txt", "w", stdout);
#endif
*/
int t = 1;
//cin>>t;
while(t--)
{
solve();
}
}
// Author : حسن
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |