UESTC-1307-windy數

來源:互聯網
上載者:User

標籤:style   blog   class   code   c   color   

windy定義了一種windy數。
不含前置字元為零且相鄰兩個數字之差至少為2的正整數被稱為windy數。
windy想知道,在A和B之間,包括A和B,總共有多少個windy數?

Input

包含兩個整數,A B。
滿足 1 <= A <= B <= 2000000000 。

Output

包含一個整數:閉區間[A,B]上windy數的個數。

Sample Input

1 10

Sample Output

9


狀態分析比較簡單,需要加入前置0的狀態 如01 02 03



#include <iostream>#include <cstdio>#include <cstring>#include <vector>#include <string>#include <algorithm>#include <queue>using namespace std;typedef long long ll;ll dp[20][10];vector<int> digit;int a,b;ll dfs(int pos,int statu,int done,int first){    if(pos==-1) return 1;    if(!done && ~dp[pos][statu]&&!first) return dp[pos][statu];    ll res = 0;    int end = done? digit[pos]:9;    if(first){        for(int i = 0; i <= end; i++)            res += dfs(pos-1,i,done&&i==end,i==0);    }    else{        for(int i = 0; i <= end; i++){            if(abs(i-statu)>=2)                res += dfs(pos-1,i,done&&i==end,0);        }    }    if(!done&&!first)   dp[pos][statu] = res;    return res;}ll solve(int num){    memset(dp,-1,sizeof dp);    digit.clear();    while(num){        digit.push_back(num%10);        num /= 10;    }    return dfs(digit.size()-1,0,1,1);}int main(){    while(cin >> a >> b){        cout<<solve(b)-solve(a-1)<<endl;    }    return 0;}


聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.