/*
Author : Chandan Agrawal
College : Poornima College of Engg. jaipur, Raj
Mail : chandanagrawal23@gmail.com
" when you are not practicing someone else is ,
and the day u meet them u will lose "
*/
#include<bits/stdc++.h>
#include<stdio.h>
using namespace std;
#define fastio ios_base::sync_with_stdio(false);cin.tie(0);cout.tie(0);
#define MAX 100050
#define ll long long
#define ld long double
#define lli int
#define pb push_back
#define INF 1000000000000
#define mod 1000000007
// trignometric function always give value in Radians only
#define PI acos(-1) //3.1415926535897932384626433832795028
#define dsin(degree) sin(degree*(PI/180.0))
#define dcos(degree) cos(degree*(PI/180.0))
#define dtan(degree) tan(degree*(PI/180.0))
#define rsin(radian) sin(radian)
#define rcos(radian) cos(radian)
#define rtan(radian) tan(radian)
#define mem0(a) memset(a,0,sizeof(a))
#define mem1(a) memset(a,-1,sizeof(a))
#define memf(a) memset(a,false,sizeof(a))
#define loop(i,n) for (lli i = 0; i < n; i++)
#define FOR(i,a,b) for (lli i = a; i < b; i++)
#define all(v) v.begin(),v.end()
#define rall(v) v.rbegin(),v.rend()
#define makeuniq(v) v.resize(unique(all(v)) - v.begin()); //only uniq element in vector after this
#define sz(x) int(x.size())
#define F first
#define S second
#define mii map<lli,lli>
#define pii pair<lli,lli>
#define vi vector<lli>
#define vvi vector<vi>
#define vpi vector<pii>
#define vbool vector<bool>
#define seti set<lli>
#define gcd(a,b) __gcd((a),(b))
#define lcm(a,b) (a/gcd(a,b))*b
#define abs(x) ((x < 0)?-(x):x)
#define endl '\n'
template <typename Head>
void print(Head&& head)
{
cout<<head<<endl;
}
template <typename Head, typename... Tail>
void print(Head&& head, Tail... tail)
{
cout<<head<<" ";
print(tail...);
}
#define scanarr(a,n) for(lli i=0;i<n;i++) cin>>a[i];
#define scanvec(a,n) for(lli i=0;i<n;i++){ lli x ; cin>>x; a.pb(x);}
#define printarr(a,n) for(lli i=0;i<n;i++) cout<<a[i]<<" "; cout<<endl;
#define printvec(vec) for(auto xt : vec) cout<<xt<<" "; cout<<"\n";
#define FD(N) fixed<<setprecision(N)
#define deb(x) cout<<#x<<" "<<x<<endl;
/*
1D vector - vi dp(n,value);
2D vector - vvi dp(n,vi(n,value));
*/
// chandan1,2
void chandan1(){int y=1;return;}
void chandan2(){
loop(i,10){
lli x=1;
}
return(chandan1());
}
//-------------------------------------------------MO's ALGO (with update) ---------------------------------------------------------------
const int blk_sz = 500; // u can take sqrt(n) too
typedef struct query
{
lli l , r , q_time , id;
query(lli L , lli R , lli Q_time , lli ID)
{
l = L;
r = R;
q_time = Q_time;
id = ID;
}
}query;
typedef struct update
{
lli ind , prev_val , new_val;
update(lli Ind , lli Prev_val , lli New_val)
{
ind = Ind;
prev_val = Prev_val;
new_val = New_val;
}
}update;
bool cmp(query a , query b)
{
lli blk_num_a_l = a.l / blk_sz;
lli blk_num_b_l = b.l / blk_sz;
if(blk_num_a_l != blk_num_b_l)
return(blk_num_a_l < blk_num_b_l);
lli blk_num_a_r = a.r / blk_sz;
lli blk_num_b_r = b.r / blk_sz;
if(blk_num_a_r != blk_num_b_r)
return(blk_num_a_r < blk_num_b_r);
return(a.q_time < b.q_time);
}
lli a[MAX] , cnt=0 , total = 0;
unordered_map<lli,lli> freq;
vector<query> q;
vector<update> upd;
void add(lli pos)
{
freq[a[pos]]++;
if((freq[a[pos]] == 1) and (a[pos]%3==0))
total += a[pos];
}
void remove(lli pos)
{
freq[a[pos]]--;
if((freq[a[pos]] == 0) and (a[pos]%3==0))
total -= a[pos];
}
//------------------------------------------------- MO's ALGO (with update) ---------------------------------------------------------------
lli ML = 0 , MR = -1;
void updo(lli pos)
{
lli new_val = upd[pos].new_val;
lli index = upd[pos].ind;
if((index >= ML) and (index <= MR) ) remove(index);
a[index] = new_val;
if((index >= ML) and (index <= MR) ) add(index);
}
void undo(lli pos)
{
lli prev_val = upd[pos].prev_val;
lli index = upd[pos].ind;
if((index >= ML) and (index <= MR) ) remove(index);
a[index] = prev_val;
if((index >= ML) and (index <= MR) ) add(index);
}
int main(){
fastio
lli t=1;
//cin>>t;
chandan2();
while(t--) {
lli n,m;
cin>>n>>m;
loop(i,n)
cin>>a[i];
lli updates = 0;
loop(i,m)
{
lli type;
cin>>type;
if(type == 0) //update query
{
lli ind , val;
cin>>ind>>val;
ind--;
updates++;
upd.pb({ind , a[ind] , val}); //index , prev_val , new_val;
}
else // ask query
{
lli l , r;
cin>>l>>r;
--l,--r;
q.pb({l,r,updates,i});
}
}
sort(all(q),cmp);
lli ans[m];
mem1(ans);
lli cr_time = 0;
for(auto xt : q)
{
lli l =xt.l;
lli r = xt.r;
lli qt = xt.q_time; // how many updates till this query ?
lli id = xt.id;
// print(l,r,qt,id);
while(cr_time < qt)
{
updo(cr_time);
cr_time++;
}
while(cr_time > qt)
{
cr_time--;
undo(cr_time);
}
// STANDARD MO -
while(MR < r)
{
MR++;
add(MR);
}
while(MR > r)
{
remove(MR);
MR--;
}
while(ML < l)
{
remove(ML);
ML++;
}
while(ML > l)
{
ML--;
add(ML);
}
ans[id] = total;
}
loop(i,m)
{
if(ans[i]!= -1)
print(ans[i]);
}
}
return 0;
}
//https://t...content-available-to-author-only...h.co/p/distinct-dishting
LyoKQXV0aG9yIDogQ2hhbmRhbiBBZ3Jhd2FsCkNvbGxlZ2UgOiBQb29ybmltYSBDb2xsZWdlIG9mIEVuZ2cuIGphaXB1ciwgUmFqCk1haWwgOiBjaGFuZGFuYWdyYXdhbDIzQGdtYWlsLmNvbQoKCiIgd2hlbiB5b3UgYXJlIG5vdCBwcmFjdGljaW5nIHNvbWVvbmUgZWxzZSBpcyAsCiBhbmQgdGhlIGRheSB1IG1lZXQgdGhlbSB1IHdpbGwgbG9zZSAiCgoqLwojaW5jbHVkZTxiaXRzL3N0ZGMrKy5oPgojaW5jbHVkZTxzdGRpby5oPgp1c2luZyBuYW1lc3BhY2Ugc3RkOwoKI2RlZmluZSBmYXN0aW8gaW9zX2Jhc2U6OnN5bmNfd2l0aF9zdGRpbyhmYWxzZSk7Y2luLnRpZSgwKTtjb3V0LnRpZSgwKTsKI2RlZmluZSBNQVggMTAwMDUwCgojZGVmaW5lIGxsIGxvbmcgbG9uZwojZGVmaW5lIGxkIGxvbmcgZG91YmxlCiNkZWZpbmUgbGxpIGludAoKI2RlZmluZSBwYiBwdXNoX2JhY2sKI2RlZmluZSBJTkYgMTAwMDAwMDAwMDAwMAojZGVmaW5lIG1vZCAxMDAwMDAwMDA3CgovLyB0cmlnbm9tZXRyaWMgZnVuY3Rpb24gYWx3YXlzIGdpdmUgdmFsdWUgaW4gUmFkaWFucyBvbmx5CiNkZWZpbmUgUEkgYWNvcygtMSkgLy8zLjE0MTU5MjY1MzU4OTc5MzIzODQ2MjY0MzM4MzI3OTUwMjgKI2RlZmluZSBkc2luKGRlZ3JlZSkgc2luKGRlZ3JlZSooUEkvMTgwLjApKQojZGVmaW5lIGRjb3MoZGVncmVlKSBjb3MoZGVncmVlKihQSS8xODAuMCkpCiNkZWZpbmUgZHRhbihkZWdyZWUpIHRhbihkZWdyZWUqKFBJLzE4MC4wKSkKCiNkZWZpbmUgcnNpbihyYWRpYW4pIHNpbihyYWRpYW4pCiNkZWZpbmUgcmNvcyhyYWRpYW4pIGNvcyhyYWRpYW4pCiNkZWZpbmUgcnRhbihyYWRpYW4pIHRhbihyYWRpYW4pCgojZGVmaW5lIG1lbTAoYSkgbWVtc2V0KGEsMCxzaXplb2YoYSkpCiNkZWZpbmUgbWVtMShhKSBtZW1zZXQoYSwtMSxzaXplb2YoYSkpCiNkZWZpbmUgbWVtZihhKSBtZW1zZXQoYSxmYWxzZSxzaXplb2YoYSkpCgojZGVmaW5lIGxvb3AoaSxuKSAgZm9yIChsbGkgaSA9IDA7IGkgPCBuOyBpKyspCiNkZWZpbmUgRk9SKGksYSxiKSBmb3IgKGxsaSBpID0gYTsgaSA8IGI7IGkrKykKCiNkZWZpbmUgYWxsKHYpIHYuYmVnaW4oKSx2LmVuZCgpCiNkZWZpbmUgcmFsbCh2KSB2LnJiZWdpbigpLHYucmVuZCgpCiNkZWZpbmUgbWFrZXVuaXEodikgdi5yZXNpemUodW5pcXVlKGFsbCh2KSkgLSB2LmJlZ2luKCkpOyAvL29ubHkgdW5pcSBlbGVtZW50IGluIHZlY3RvciBhZnRlciB0aGlzCiNkZWZpbmUgc3ooeCkgaW50KHguc2l6ZSgpKQojZGVmaW5lIEYgZmlyc3QKI2RlZmluZSBTIHNlY29uZAoKI2RlZmluZSBtaWkgbWFwPGxsaSxsbGk+CgojZGVmaW5lIHBpaSBwYWlyPGxsaSxsbGk+CgojZGVmaW5lIHZpIHZlY3RvcjxsbGk+CiNkZWZpbmUgdnZpIHZlY3Rvcjx2aT4KI2RlZmluZSB2cGkgdmVjdG9yPHBpaT4KI2RlZmluZSB2Ym9vbCB2ZWN0b3I8Ym9vbD4KCiNkZWZpbmUgc2V0aSBzZXQ8bGxpPgoKI2RlZmluZSBnY2QoYSxiKSBfX2djZCgoYSksKGIpKQojZGVmaW5lIGxjbShhLGIpIChhL2djZChhLGIpKSpiCiNkZWZpbmUgYWJzKHgpICgoeCA8IDApPy0oeCk6eCkKCiNkZWZpbmUgZW5kbCAnXG4nCgp0ZW1wbGF0ZSA8dHlwZW5hbWUgSGVhZD4Kdm9pZCBwcmludChIZWFkJiYgaGVhZCkKewogICAgY291dDw8aGVhZDw8ZW5kbDsKfQp0ZW1wbGF0ZSA8dHlwZW5hbWUgSGVhZCwgdHlwZW5hbWUuLi4gVGFpbD4Kdm9pZCBwcmludChIZWFkJiYgaGVhZCwgVGFpbC4uLiB0YWlsKQp7CiAgICBjb3V0PDxoZWFkPDwiICI7CiAgICBwcmludCh0YWlsLi4uKTsKfQoKI2RlZmluZSBzY2FuYXJyKGEsbikgZm9yKGxsaSBpPTA7aTxuO2krKykgICAgY2luPj5hW2ldOwojZGVmaW5lIHNjYW52ZWMoYSxuKSBmb3IobGxpIGk9MDtpPG47aSsrKXsgbGxpIHggOyBjaW4+Png7IGEucGIoeCk7fQoKI2RlZmluZSBwcmludGFycihhLG4pIGZvcihsbGkgaT0wO2k8bjtpKyspICAgY291dDw8YVtpXTw8IiAiOyBjb3V0PDxlbmRsOwojZGVmaW5lIHByaW50dmVjKHZlYykgZm9yKGF1dG8geHQgOiB2ZWMpIGNvdXQ8PHh0PDwiICI7ICAgIGNvdXQ8PCJcbiI7CgojZGVmaW5lIEZEKE4pIGZpeGVkPDxzZXRwcmVjaXNpb24oTikKCiNkZWZpbmUgZGViKHgpIGNvdXQ8PCN4PDwiICI8PHg8PGVuZGw7CgovKgoxRCB2ZWN0b3IgLSAgdmkgZHAobix2YWx1ZSk7CjJEIHZlY3RvciAtICB2dmkgZHAobix2aShuLHZhbHVlKSk7CiovCgovLyBjaGFuZGFuMSwyCnZvaWQgY2hhbmRhbjEoKXtpbnQgeT0xO3JldHVybjt9CnZvaWQgY2hhbmRhbjIoKXsKICAgICAgICBsb29wKGksMTApewogICAgICAgIGxsaSB4PTE7CiAgICB9CiAgICByZXR1cm4oY2hhbmRhbjEoKSk7Cn0KCi8vLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLU1PJ3MgQUxHTyAod2l0aCB1cGRhdGUpIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQoKCmNvbnN0IGludCBibGtfc3ogPSA1MDA7IC8vIHUgY2FuIHRha2Ugc3FydChuKSB0b28gCgp0eXBlZGVmIHN0cnVjdCBxdWVyeQp7CiAgICBsbGkgbCAsIHIgLCBxX3RpbWUgLCBpZDsKICAgIHF1ZXJ5KGxsaSBMICwgbGxpIFIgLCBsbGkgUV90aW1lICwgbGxpIElEKQogICAgewogICAgICAgIGwgPSBMOwogICAgICAgIHIgPSBSOwogICAgICAgIHFfdGltZSA9IFFfdGltZTsKICAgICAgICBpZCA9IElEOwogICAgfQp9cXVlcnk7CgoKCnR5cGVkZWYgc3RydWN0IHVwZGF0ZQp7CiAgICBsbGkgaW5kICwgcHJldl92YWwgLCBuZXdfdmFsOwogICAgdXBkYXRlKGxsaSBJbmQgLCBsbGkgUHJldl92YWwgLCBsbGkgTmV3X3ZhbCkKICAgIHsKICAgICAgICBpbmQgPSBJbmQ7CiAgICAgICAgcHJldl92YWwgPSBQcmV2X3ZhbDsKICAgICAgICBuZXdfdmFsID0gTmV3X3ZhbDsKICAgIH0KfXVwZGF0ZTsKCmJvb2wgY21wKHF1ZXJ5IGEgLCBxdWVyeSBiKQp7CiAgICBsbGkgYmxrX251bV9hX2wgPSBhLmwgLyBibGtfc3o7CiAgICBsbGkgYmxrX251bV9iX2wgPSBiLmwgLyBibGtfc3o7CiAgICAKICAgIGlmKGJsa19udW1fYV9sICE9IGJsa19udW1fYl9sKQogICAgICAgIHJldHVybihibGtfbnVtX2FfbCA8IGJsa19udW1fYl9sKTsKICAgICAgICAKICAgIGxsaSBibGtfbnVtX2FfciA9IGEuciAvIGJsa19zejsKICAgIGxsaSBibGtfbnVtX2JfciA9IGIuciAvIGJsa19zejsKICAgIAogICAgaWYoYmxrX251bV9hX3IgIT0gYmxrX251bV9iX3IpCiAgICAgICAgcmV0dXJuKGJsa19udW1fYV9yIDwgYmxrX251bV9iX3IpOwogICAgCiAgICByZXR1cm4oYS5xX3RpbWUgPCBiLnFfdGltZSk7Cn0KCgpsbGkgYVtNQVhdICwgY250PTAgLCB0b3RhbCA9IDA7CnVub3JkZXJlZF9tYXA8bGxpLGxsaT4gZnJlcTsKdmVjdG9yPHF1ZXJ5PiBxOwp2ZWN0b3I8dXBkYXRlPiB1cGQ7CgoKdm9pZCBhZGQobGxpIHBvcykKewogICAgZnJlcVthW3Bvc11dKys7CiAgICBpZigoZnJlcVthW3Bvc11dID09IDEpIGFuZCAoYVtwb3NdJTM9PTApKQogICAgICAgIHRvdGFsICs9IGFbcG9zXTsKfQogCnZvaWQgcmVtb3ZlKGxsaSBwb3MpCnsKICAgIGZyZXFbYVtwb3NdXS0tOwogICAgaWYoKGZyZXFbYVtwb3NdXSA9PSAwKSBhbmQgKGFbcG9zXSUzPT0wKSkKICAgICAgICB0b3RhbCAtPSBhW3Bvc107Cn0KCgoKCi8vLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSBNTydzIEFMR08gKHdpdGggdXBkYXRlKSAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCmxsaSBNTCA9IDAgLCBNUiA9IC0xOwoKdm9pZCB1cGRvKGxsaSBwb3MpCnsKICAgIGxsaSBuZXdfdmFsID0gdXBkW3Bvc10ubmV3X3ZhbDsKICAgIGxsaSBpbmRleCA9IHVwZFtwb3NdLmluZDsKICAgIAogICAgaWYoKGluZGV4ID49IE1MKSBhbmQgKGluZGV4IDw9IE1SKSApIHJlbW92ZShpbmRleCk7CiAgICAKICAgIGFbaW5kZXhdID0gbmV3X3ZhbDsKICAgIAogICAgaWYoKGluZGV4ID49IE1MKSBhbmQgKGluZGV4IDw9IE1SKSApIGFkZChpbmRleCk7CiAgICAKICAgIAp9Cgp2b2lkIHVuZG8obGxpIHBvcykKewogICAgbGxpIHByZXZfdmFsID0gdXBkW3Bvc10ucHJldl92YWw7CiAgICBsbGkgaW5kZXggPSB1cGRbcG9zXS5pbmQ7CiAgICAKICAgIGlmKChpbmRleCA+PSBNTCkgYW5kIChpbmRleCA8PSBNUikgKSByZW1vdmUoaW5kZXgpOwogICAgCiAgICBhW2luZGV4XSA9IHByZXZfdmFsOwogICAgCiAgICBpZigoaW5kZXggPj0gTUwpIGFuZCAoaW5kZXggPD0gTVIpICkgYWRkKGluZGV4KTsKfQoKaW50IG1haW4oKXsKZmFzdGlvCmxsaSB0PTE7Ci8vY2luPj50OwpjaGFuZGFuMigpOwp3aGlsZSh0LS0pIHsKICAgIGxsaSBuLG07CiAgICBjaW4+Pm4+Pm07CiAgICBsb29wKGksbikKICAgICAgICBjaW4+PmFbaV07CiAgICAgICAgCiAgICAKICAgIGxsaSB1cGRhdGVzID0gMDsKICAgIGxvb3AoaSxtKQogICAgewogICAgICAgIGxsaSB0eXBlOwogICAgICAgIGNpbj4+dHlwZTsKICAgICAgICBpZih0eXBlID09IDApIC8vdXBkYXRlIHF1ZXJ5CiAgICAgICAgewogICAgICAgICAgICBsbGkgaW5kICwgdmFsOwogICAgICAgICAgICBjaW4+PmluZD4+dmFsOwogICAgICAgICAgICBpbmQtLTsKICAgICAgICAgICAgdXBkYXRlcysrOwogICAgICAgICAgICB1cGQucGIoe2luZCAsIGFbaW5kXSAsIHZhbH0pOyAvL2luZGV4ICwgcHJldl92YWwgLCBuZXdfdmFsOwogICAgICAgIH0KICAgICAgICBlbHNlIC8vIGFzayBxdWVyeQogICAgICAgIHsKICAgICAgICAgICBsbGkgbCAsIHI7CiAgICAgICAgICAgY2luPj5sPj5yOwogICAgICAgICAgICAtLWwsLS1yOwogICAgICAgICAgICBxLnBiKHtsLHIsdXBkYXRlcyxpfSk7IAogICAgICAgIH0KICAgICAgICAKICAgIH0KICAgIAogICAgc29ydChhbGwocSksY21wKTsKICAgIAogICAgbGxpIGFuc1ttXTsKICAgIG1lbTEoYW5zKTsKICAgIAogICAgbGxpIGNyX3RpbWUgPSAwOwogICAgCiAgICBmb3IoYXV0byB4dCA6IHEpCiAgICB7CiAgICAgICAgbGxpIGwgPXh0Lmw7CiAgICAgICAgbGxpIHIgPSB4dC5yOwogICAgICAgIGxsaSBxdCA9IHh0LnFfdGltZTsgLy8gaG93IG1hbnkgdXBkYXRlcyB0aWxsIHRoaXMgcXVlcnkgPwogICAgICAgIGxsaSBpZCA9IHh0LmlkOwogICAgICAgIAogICAgICAgLy8gcHJpbnQobCxyLHF0LGlkKTsKICAgICAgICAKICAgICAgICB3aGlsZShjcl90aW1lIDwgcXQpCiAgICAgICAgewogICAgICAgICAgICB1cGRvKGNyX3RpbWUpOwogICAgICAgICAgICBjcl90aW1lKys7CiAgICAgICAgfQogICAgICAgIAogICAgICAgIHdoaWxlKGNyX3RpbWUgPiBxdCkKICAgICAgICB7CiAgICAgICAgICAgIGNyX3RpbWUtLTsKICAgICAgICAgICAgdW5kbyhjcl90aW1lKTsKICAgICAgICB9CiAgICAgICAgCiAgICAgICAgLy8gU1RBTkRBUkQgTU8gLSAKICAgICAgICAKICAgICAgICB3aGlsZShNUiA8IHIpCiAgICAgICAgewogICAgICAgICAgICBNUisrOwogICAgICAgICAgICBhZGQoTVIpOwogICAgICAgIH0KICAgICAgICAKICAgICAgICB3aGlsZShNUiA+IHIpCiAgICAgICAgewogICAgICAgICAgICByZW1vdmUoTVIpOwogICAgICAgICAgICBNUi0tOwogICAgICAgIH0KICAgICAgICAKICAgICAgICAKICAgICAgICB3aGlsZShNTCA8IGwpCiAgICAgICAgewogICAgICAgICAgICByZW1vdmUoTUwpOwogICAgICAgICAgICBNTCsrOwogICAgICAgIH0KICAgICAgICAKICAgICAgICB3aGlsZShNTCA+IGwpCiAgICAgICAgewogICAgICAgICAgICBNTC0tOwogICAgICAgICAgICBhZGQoTUwpOwogICAgICAgIH0KCiAgICAgICAgYW5zW2lkXSA9IHRvdGFsOwogICAgfQogICAgCiAgICBsb29wKGksbSkKICAgIHsKICAgICAgICBpZihhbnNbaV0hPSAtMSkKICAgICAgICAgICAgcHJpbnQoYW5zW2ldKTsKICAgIH0KICB9CnJldHVybiAwOwp9CgovL2h0dHBzOi8vdC4uLmNvbnRlbnQtYXZhaWxhYmxlLXRvLWF1dGhvci1vbmx5Li4uaC5jby9wL2Rpc3RpbmN0LWRpc2h0aW5n