A. Nearly Lucky Number

这道水题在涛神的帮助下顺利过关,一下是几个泪点

1,英语不过关:In the second sample there are 7 lucky digits, 7 is lucky number, so the answer is "YES".它指的是7位数,digit位数,如果位数是幸运数字则输出,这个没考虑到

2,这个lucky number不一定全都是幸运数字,4444000.7777444都是lucky number,一定要把题目要求看仔细。

3,不管是不是lucky number 在用s统计位数的时候,num都要除以10(详见代码)

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 477444 are lucky and 517467 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).

Sample test(s)
input
40047
output
NO
input
7747774
output
YES
input
1000000000000000000
output
NO
Note

In the first sample there are 3 lucky digits (first one and last two), so the answer is "NO".

In the second sample there are 7 lucky digits, 7 is lucky number, so the answer is "YES".

In the third sample there are no lucky digits, so the answer is "NO".


#include<iostream>
using namespace std;

int main()
{
    long long  s;
    cin>>s;
    int c=0,i;
    while(s)
    {
    i=s%10;
    if((s%10==7)||(s%10==4))  c++;
    s=s/10;//这句别写在if 语句里面
    }
    if(c==7||c==4) cout<<"YES"<<endl;
    else cout<<"NO"<<endl;
    return 0;

}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是汇编代码实现: ``` strconvert: push ebx ; 保存 ebx 的值 mov ecx, ebx ; 将字符串首地址存入 ecx xor eax, eax ; 初始化为 0 loop1: mov bl, byte [ecx] ; 将 ecx 指向的字符存入 bl cmp bl, '$' ; 判断是否到达字符串结尾 je end_loop1 cmp bl, 'a' ; 判断字符是否为小写字母 jl loop2 cmp bl, 'z' jg loop2 sub bl, 32 ; 将小写字母转为大写字母 mov byte [ecx], bl ; 将转换后的字符存回字符串中 loop2: inc ecx ; 将 ecx 指向下一个字符 jmp loop1 end_loop1: pop ebx ; 恢复 ebx 的值 ret ``` 解释: 1. `push ebx`:将 ebx 的值保存在栈中,以便函数结束时恢复 ebx 的值。 2. `mov ecx, ebx`:将字符串首地址存入 ecx,方便后面进行循环操作。 3. `xor eax, eax`:将 eax 初始化为 0,以便后面进行比较判断。 4. `loop1:`:循环开始。 5. `mov bl, byte [ecx]`:将 ecx 指向的字符存入 bl。 6. `cmp bl, '$'`:判断是否到达字符串结尾,如果是则跳转至循环结束。 7. `cmp bl, 'a'`:判断字符是否为小写字母,如果不是则跳转至 loop2。 8. `jl loop2`:如果字符小于 'a',则跳转至 loop2。 9. `cmp bl, 'z'`:判断字符是否为大写字母,如果不是则跳转至 loop2。 10. `jg loop2`:如果字符大于 'z',则跳转至 loop2。 11. `sub bl, 32`:将小写字母转为大写字母。 12. `mov byte [ecx], bl`:将转换后的字符存回字符串中。 13. `inc ecx`:将 ecx 指向下一个字符。 14. `jmp loop1`:跳转至循环开始。 15. `end_loop1:`:循环结束。 16. `pop ebx`:恢复 ebx 的值。 17. `ret`:返回函数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值