#include<iostream>
using namespace std;
const int maxn=1e6+5;
//打表
//题意:每个数字的圈圈,理解成对应余数的标记,对于一个多位数,就是考虑其每一位的圈圈,即从从右到做左依次做模运算的余数
long long record[maxn]={0};
void solve()
{
for(int i=0;i<=maxn;i++)
{
int temp=i;
while(temp!=0)
{
int m=temp%10;
if(m==0||m==4||m==6||m==9)
record[i]++;
else if(m==8)
record[i]+=2;
temp/=10;
}
}
}
int main()
{
int t;
cin>>t;
solve();//注意此处调用下
while(t--)
{
int a,b;
int sum=0;
cin>>a>>b;
for(int i=a;i<=b;i++)
{
sum+=record[i];
}
cout<<sum<<endl;
}
return 0;
}

京公网安备 11010502036488号