/* 题目内容:

YF不爱名利,所以他既不喜欢6,也不喜欢8。他的幸运数字是4和7。如果一个数字中只包含4和7,他就认为这个数字是他的幸运数。
现在给你两个正整数a,b,要求返回a,b之间的幸运数的个数,包括a,b本身。

输入描述

第一行输入数目n,表示后面有n组ab
第2行开始,每行一组a b, 空格隔开。


输出描述

每行输出一个数,即a,b之间的幸运数的个数。


输入样例

3
11 20
4 7
1 10
输出样例

0
2
2
*/

#include <iostream>
using namespace std;
int lucky[10000005]; //注意大小,小了一直是 答案错误

void countlucky(){
    for(int i = 1; i <= 10000000; i++){
        int c, d, e, f, g, h, y = i;
        int flag = 1;
        if(y % 10 == 0)
            flag = 0;
        while(y % 10 && flag){
            c = y % 10; y /= 10;
            if(c != 4 && c != 7)
                flag = 0;
        }
        if(flag && y == 0)  // 101 y = 10
            lucky[i] = 1;
//        c = y % 10; y /= 10;
//        d = y % 10; y /= 10;
//        e = y % 10; y /= 10;
//        f = y % 10; y /= 10;
//        g = y % 10; y /= 10;
//        h = y % 10; y /= 10;
//        if(i < 10)
//            lucky[4] = lucky[7] = 1;
//        if(i < 100){
//            if((c == 4 || c == 7) && (d == 4 || d == 7))
//                lucky[i] = 1;
//        }
//        if(i < 1000 && (c == 4 || c == 7) && (d == 4 || d == 7) && (e == 4 || e == 7))
//            lucky[i] = 1;
//        if(i < 10000 && (c == 4 || c == 7) && (d == 4 || d == 7) && (e == 4 || e == 7) && (f == 4 || f == 7))
//            lucky[i] = 1;
//        if(i < 100000 && (c == 4 || c == 7) && (d == 4 || d == 7) && (e == 4 || e == 7) && (f == 4 || f == 7)
//          && (g == 4 || g == 7))
//            lucky[i] = 1;
//        if(i < 100000 && (c == 4 || c == 7) && (d == 4 || d == 7) && (e == 4 || e == 7) && (f == 4 || f == 7)
//          && (g == 4 || g == 7) && (h == 4 || h == 7))
//            lucky[i] = 1;     
        lucky[i] += lucky[i - 1];
    }
}

int main(){
    ios::sync_with_stdio(false);
    int n;
//    cin >> n;
    countlucky();
//    while(n--){
        int a, b;
        cin >> a >> b;
        cout << lucky[b] - lucky[a - 1] << endl;
//    }
    return 0;
}