// LUOGU_RID: 106063699
#include<bits/stdc++.h>
using namespace std;
const int N=1e5+5;
int n,m,a[N],f[N],c[N];
char ch[10];
void get(int x)
{
if(x*10+7<=10000)
{
f[x*10+7]=1;
get(x*10+7);
}
if(x*10+4<=10000)
{
f[x*10+4]=1;
get(x*10+4);
}
}
void add(int x,int y){
for(;x<=n;x+=x&-x) {
c[x]+=y;
}
}
int ask(int x)
{
int res=0;
for(;x;x-=x&-x) res+=c[x];
return res;
}
int main()
{
scanf("%d%d",&n,&m);
get(0);
for(int i=1;i<=n;i++)
{
scanf("%d",&a[i]);
if(f[a[i]])
{
add(i,1);
}
}
while(m--)
{
scanf("%s",ch); int l,r,val;
if(ch[0]=='c')
{
scanf("%d%d",&l,&r);
printf("%d\n",ask(r)-ask(l-1));
}
else
{
scanf("%d%d%d",&l,&r,&val);
for(int i=l;i<=r;i++)
{
if(f[a[i]]) add(i,-1);
a[i]+=val;
if(f[a[i]]) add(i,1);
}
}
}
return 0;
}
1619B - Squares and Cubes | 1619A - Square String |
1629B - GCD Arrays | 1629A - Download More RAM |
1629C - Meximum Array | 1629D - Peculiar Movie Preferences |
1629E - Grid Xor | 1629F1 - Game on Sum (Easy Version) |
2148. Count Elements With Strictly Smaller and Greater Elements | 2149. Rearrange Array Elements by Sign |
2150. Find All Lonely Numbers in the Array | 2151. Maximum Good People Based on Statements |
2144. Minimum Cost of Buying Candies With Discount | Non empty subsets |
1630A - And Matching | 1630B - Range and Partition |
1630C - Paint the Middle | 1630D - Flipping Range |
1328A - Divisibility Problem | 339A - Helpful Maths |
4A - Watermelon | 476A - Dreamoon and Stairs |
1409A - Yet Another Two Integers Problem | 977A - Wrong Subtraction |
263A - Beautiful Matrix | 180C - Letter |
151A - Soft Drinking | 1352A - Sum of Round Numbers |
281A - Word Capitalization | 1646A - Square Counting |