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 <bitset>
#include <cmath>
#include <functional>
#include <algorithm>
#include <numeric>
#include <deque>
#include <fstream>
#include <iomanip>
#include <iostream>
#include <iterator>
#include <limits>
#include <list>
#include <map>
#include <unordered_map>
#include <queue>
#include <set>
#include <stack>
#include <string>
#include <vector>
#include <cstring>
#include <climits>
#define int long long
#define pb push_back
#define MOD 1000000007
#define NMAX 100005
#define nl '\n'
#define INF 1000000007
#define pii1 pair<int, pair<int,int>> (1,(1,2));
#define pii pair<int,int>
#define tpl tuple<int,int,int>
using namespace std;
ifstream fin("data.in");
ofstream fout("data.out");
class segtree{
private:
int n;
vector<vector<int>>tree;
public:
void init(int sz)
{
n=sz;
tree.resize(4*sz+1);
}
vector<int> calc(vector<int>a, vector<int>b)
{
for(auto x:b)
a.pb(x);
return a;
}
void build(int node,int st,int dr,vector<int>&v) {
if (st == dr) {
tree[node] = {v[st]};
return;
}
int mid = (st + dr) / 2;
build(2 * node, st, mid, v);
build(2 * node + 1, mid + 1, dr, v);
tree[node] = calc(tree[2 * node],tree[2 * node + 1]);
}
void update(int node,int st,int dr,int pos,int val)
{
if(st==dr)
{
tree[node]={val};
return;
}
int mid=(st+dr)/2;
if(pos<=mid)
update(2*node,st,mid,pos,val);
else
update(2*node+1,mid+1,dr,pos,val);
tree[node]=calc(tree[2*node],tree[2*node+1]);
}
vector<int> query(int node,int st,int dr,int L,int R)
{
if(R<st ||dr<L)
return {};
if(L<=st && dr<=R)
{
return tree[node];
}
int mid=(st+dr)/2;
vector<int> left=query(2*node,st,mid,L,R);
vector<int> right=query(2*node+1,mid+1,dr,L,R);
return calc(left,right);
}
void build(vector<int>&v)
{
build(1,1,n,v);
}
void update(int pos,int val)
{
update(1,1,n,pos,val);
}
vector<int> query(int L,int R)
{
return query(1,1,n,L,R);
}
};
/*
* 8 3
7 2 5 1 9 3 4 6
3
2 2 7 4
1 2 5 8
2 2 7 3
72519346
7251 9346
72 51 93 46
7 2 5 1 9 3 4 6
ind:
m=1 -> 7 2 5 1 9 3 4 6 -> 1 1 1 1 1 1 1 1
m=2 -> 7 2 2 5 5 1 1 9 9 3 3 4 4 6-> 1 2 2 2 2 2 2 1
m=3 -> 7 2 5 2 5 1 5 1 9 1 9 3 9 3 4 3 4 6 -> 1 2 3 3 3 3 2 1
/ m=4 -> 7 2 5 1 2 5 1 9 5 1 9 3 1 9 3 4 9 3 4 6-> 1 2 3 4 4 3 2 1
m=5 -> 7 2 5 1 9 2 5 1 9 3 5 1 9 3 4 1 9 3 4 6 -> 1 2 3 4 4 3 2 1
m=6 -> 7 2 5 1 9 3 4 6 2 5 1 9 3 4 6 5 1 9 3 4 6 -> 1 2 3 3 3 3 2 1
m=7 -> 7 2 5 1 9 3 4 2 5 1 9 3 4 6 ->1 2 2 2 2 2 2 1
m=8 7 2 5 1 9 3 4 6 -> 1 1 1 1 1 1 1 1
1 2 3 4 5 6 7 8 9 10 11 12
m=6 -> 1 2 3 4 5 6 2 3 4 5 6 7 3 4 5 6 7 8 4 5 6 7 8 9 5 6 7 8 9 10 6 7 8 9 10 11 7 8 9 10 11 12-> 1 2 3 4 5 6 6 5 4 3 2 1
lenght=m;
frq[ind][i]=min(i,m) ,ind<=length/2
frq[ind][i]frq[lenth-ind+1][i] ,ind>=length/2;
*/
segtree st;
signed main() {
int n,k;
cin>>n>>k;
vector<int>v(n+1);
st.init(n);
for(int i=1;i<=n;++i)
{
cin>>v[i];
}
st.build(v);
int q;
cin>>q;
while(q--)
{
int type;
cin>>type;
if(type==1)
{
int x;
for(int i=1;i<=k;++i)
{
cin>>x;
}
}
else
{
int l,r,m;
cin>>l>>r>>m;
vector<int>ans=st.query(l,r);
int res=0;
int aux=0;
int ind=0;
for(int i=0;i<m;++i)
{
aux+=ans[i];
}
res+=aux;
for(int i=m;i<ans.size();++i)
{
aux-=ans[ind];
aux+=ans[i];
ind++;
res+=aux;
}
cout<<res<<nl;
}
}
return 0;
}
Compilation message (stderr)
Main.cpp: In function 'int main()':
Main.cpp:173:26: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<long long int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
173 | for(int i=m;i<ans.size();++i)
| ~^~~~~~~~~~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |