奶牛在数学课上学习了整除的概念。农夫 Farmer John 为了考验它的数学水平,于是在 白纸上写了正整数 T。由于农夫不喜欢数字 0,所以正整数 T 是不含数字 0 的。奶牛可以 删除 T 的若干位数字,剩下来的数字从左到右构成一个正整数 P,使得正整数 P 必须是 5 的倍数。奶牛有多少种不同的删除方案?
输入
第一行,一个正整数 T
T 的位数的范围是 30 位至 60 位
输出
一个整数,奶牛不同的删除方案数。
提示:
1、奶牛可以删除 0 个数字(即不删除任何数字)。
2、奶牛不能把 T 全部删除掉。即至少要剩下 1 位数字。
3、由于 T 的位数可能较长,建议用字符串形式读入。
#include<bits/stdc++.h>
using namespace std;
string a;
long long b[65],s;
int main(){
cin>>a;
b[0]=1;
for(int i=0;i<a.size();i++){
if(i>0)b[i]=b[i-1]*2;
if(a[i]=='5')s+=b[i];
}
cout<<s;
return 0;
}
2174

被折叠的 条评论
为什么被折叠?



