1 7
2
思路:和丑数思路一样 用前面的数便利出后面的数
打个表
然后判断l,r在表中的位置,统计unlucky numbers就行了
#include<iostream> #include<stdio.h> #include<string.h> #include<algorithm> using namespace std; long long a[1000000]; int c; void init() { c=0; a[c++]=1; a[c++]=7; int k=0; while(a[c-1]<1e18) { a[c++]=a[k]*10+1; a[c++]=a[k]*10+7; k++; } } int main() { init(); long long l,r; while(cin>>l>>r) { int L=0,R=0; for(int i=0; i<c; i++) { if(a[i]<=l) L=i; if(a[i]>r) { R=i; break; } } if(a[L]==l||l==0) L--; printf("%d\n",R-L-1); } }
原文地址:http://blog.csdn.net/u012349696/article/details/41651201