이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#define sz(x) ((int)x.size())
#define all(x) (x).begin(), (x).end()
#define fi first
#define se second
using namespace std;
typedef long long ll;
typedef long double ld;
typedef pair<int,int> pii;
typedef pair<ll,ll> pll;
ll N,dp[20][11][11][2],pw[20];
ll go(int pos,int pre, int cur, int eql) {
if(pos==0) return 1;
ll& ret=dp[pos][pre][cur][eql];
if(ret!=-1) return ret;
ret=0;
int i,j=N/pw[pos-1]%10;
if(eql) {
if(j!=pre && j!=cur)
ret+=go(pos-1, cur, j, eql);
}
for(i=0;i<(eql?j:10);i++) {
if(i==pre || i==cur) continue;
ret+=go(pos-1,cur,i,0);
}
return ret;
}
ll f(ll n) {
if(n==0) return 0;
N=n;
memset(dp,-1,sizeof(dp));
ll v=1; int pos=0;
while(n/v>=10) v*=10, pos++;
ll ret=0;
int i,j;
for(i=pos;i>=0;i--) {
if(i==pos) ret+=go(i,10,n/v%10,1);
for(j=1;j<(i==pos?n/v%10:10);j++)
ret+=go(i,10,j,0);
}
return ret;
}
int main() {
int i;
pw[0]=1;
for(i=1;i<20;i++) pw[i]=10*pw[i-1];
ll a,b;
scanf("%lld%lld",&a,&b);
printf("%lld",f(b)-f(a-1));
return 0;
}
컴파일 시 표준 에러 (stderr) 메시지
numbers.cpp: In function 'int main()':
numbers.cpp:48:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
scanf("%lld%lld",&a,&b);
~~~~~^~~~~~~~~~~~~~~~~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |