zoukankan      html  css  js  c++  java
  • Loj10164 数字游戏1

    题目描述

    科协里最近很流行数字游戏。某人命名了一种不降数,这种数字必须满足从左到右各位数字成小于等于的关系,如 123446。现在大家决定玩一个游戏,指定一个整数闭区间 [a,b][a,b][a,b],问这个区间内有多少个不降数。


    数位DP的模板,记忆化搜索时枚举从当前状态开始就行。具体看注释

    #include <iostream>
    #include <cstdio>
    #include <algorithm>
    #include <cstring>
    #include <cmath>
    #include <cstdlib>
    #include <queue>
    #include <stack>
    #include <vector>
    using namespace std;
    #define MAXN 100010
    #define INF 10000009
    #define MOD 10000007
    #define LL long long    
    #define in(a) a=read()
    #define REP(i,k,n) for(int i=k;i<=n;i++)
    #define DREP(i,k,n) for(int i=k;i>=n;i--)
    #define cl(a) memset(a,0,sizeof(a))
    inline int read(){
        int x=0,f=1;char ch=getchar();
        for(;!isdigit(ch);ch=getchar()) if(ch=='-') f=-1;
        for(;isdigit(ch);ch=getchar()) x=x*10+ch-'0';
        return x*f;
    }
    inline void out(int x){
        if(x<0) putchar('-'),x=-x;
        if(x>9) out(x/10);
        putchar(x%10+'0');
    }
    int n,f[12][12],digit[12];
    LL DFS(int pos,int u,int flag){//pos代表当前位,u代表当前状态,flag判断是否越界
         if(pos==0)  return 1;//如果枚举完了,这是一种情况
         LL ans=0;
         int end;
         if(flag)  end=digit[pos];//如果当前枚举的数越界,也就是擦边,那么枚举到最大
         else  end=9;//如果当前不擦边,那么久随便枚举
         REP(i,u,end)  ans+=DFS(pos-1,i,flag && i==end);
         return ans;
     }
    LL get(int k){
        int l=0;
        while(k){
            digit[++l]=k%10;
            k/=10;
        }
        DFS(l,0,1);
    }
    int main(){
        int a,b; 
        while(cin>>a>>b)  cout<<get(b)-get(a-1)<<endl;
        return 0;    
    } 
  • 相关阅读:
    02、书店寻宝(一)
    01、博客爬虫
    00、下载文件
    068、Calico的网络结构是什么?(2019-04-11 周四)
    067、如何部署Calico网络 (2019-04-10 周三)
    066、Weave如何与外网通信?(2019-04-09 周二)
    065、容器在Weave中如何通信和隔离?(2019-04-08 周一)
    064、Weave网络结构分析(2019-04-04 周四)
    063、如何使用weave网络(2019-04-03 周三)
    CMD运行指令
  • 原文地址:https://www.cnblogs.com/jason2003/p/9852585.html
Copyright © 2011-2022 走看看