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;    
    } 
  • 相关阅读:
    linux常用快捷键
    msf远程调用OpenVAS
    (三)漏洞平台搭建-xssplatform
    (二)漏洞平台搭建-sql-lab
    (一)漏洞平台搭建-DVWA
    msf永恒之蓝漏洞利用命令总结
    解决kali无法全屏问题
    centos7源码安装mysql数据库
    【多数人的误区】十二生肖属相不是从春节开始算的!
    python元组不可变是指什么不可变
  • 原文地址:https://www.cnblogs.com/jason2003/p/9852585.html
Copyright © 2011-2022 走看看