0

Question - Petya loves lucky numbers. We all know that lucky numbers are the positive integers whose decimal representations contain only the lucky digits 4 and 7. For example, numbers 47, 744, 4 are lucky and 5, 17, 467 are not.

Unfortunately, not all numbers are lucky. Petya calls a number nearly lucky if the number of lucky digits in it is a lucky number. He wonders whether number n is a nearly lucky number.

Input - The only line contains an integer n (1 ≤ n ≤ 1018).

Please do not use the %lld specificator to read or write 64-bit numbers in С++. It is preferred to use the cin, cout streams or the %I64d specificator.

Output - Print on the single line "YES" if n is a nearly lucky number. Otherwise, print "NO" (without the quotes).

Question Link - https://codeforces.com/problemset/problem/110/A

My code -

int main(){
    int a,b=0;
    cin >> a;
    string x = to_string(a);
    for(int i=0;i<x.length();i++){
        if(x[i]=='4' || x[i]=='7'){
            b++;
        }
    }
    cout << b;
    if(b==4 || b==7){
        cout << "YES";
    }else{cout << "NO";}
}

It is passing numerous test cases but there is one which it fails. When the integer is 4744000695826 , the value of my B is 5 therefore the output is NO. I am not understanding why is the value of B = 5, whereas it should be equal to 4 and even my code seems to be working that way. What could be the possible problems?

1 Answers1

2

Integers have certain limits, and exceeding the limits can cause undefined behavior, so instead of int, long long will be used. Updated code -

int main(){
    long long a,b=0;
    cin >> a;
    string x = to_string(a);
    for(int i=0;i<x.length();i++){
        if(x[i]=='4' || x[i]=='7'){
            b++;
        }
    }
    cout << b;
    if(b==4 || b==7){
        cout << "YES";
    }else{cout << "NO";}
}