zoukankan      html  css  js  c++  java
  • [NOIP1999提高] CODEVS 1047 邮票面值设计(dfs+dp)

    dfs出邮票的各种面值,然后dp求解。

    -------------------------------------------------------------------------------

    #include<cstdio>
    #include<cstring>
    #include<algorithm>
    #include<vector>
     
    #define rep(i,n) for(int i=0;i<n;++i) 
    #define clr(x,c) memset(x,c,sizeof(x))
    #define Rep(i,l,r) for(int i=l;i<=r;++i)
     
    using namespace std;
     
    const int maxn=40;
    const int inf=5000000;
     
    vector<int> ans;
    int cur[maxn];
    int ANS=0;
    int ok[4000000];
    int n,k;
    int t=0;
     
    void jud() {
    int a=0; ok[0]=0;
    while(ok[a]<=n) {
    ok[++a]=inf;
       rep(i,k) {
        if(a<cur[i]) break;
        ok[a]=min(ok[a],ok[a-cur[i]]+1);
       }
    }
    if(--a>ANS) {
    ANS=a;
    ans.clear();
    rep(i,k) ans.push_back(cur[i]);
    }
    }
     
    void dfs(int x) {
    if(x==k) jud();
    else Rep(i,cur[x-1]+1,cur[x-1]*n+1) {
       cur[x]=i;
    dfs(x+1);
    }
    }
    int main()
    {
    freopen("test.in","r",stdin);
    freopen("test.out","w",stdout);
    scanf("%d%d",&n,&k);
    dfs(cur[0]=1);
    rep(i,ans.size()) printf("%d ",ans[i]);
    printf(" MAX=%d ",ANS);
    return 0;
    }

      

    ------------------------------------------------------------------------------- 

    1047 邮票面值设计

     

    1999年NOIP全国联赛提高组

     时间限制: 1 s
     空间限制: 128000 KB
     题目等级 : 钻石 Diamond
  • 相关阅读:
    .NET平台系列18 .NET5的超强优势
    .NET平台系列17 .NET5中的ARM64性能
    .NET平台系列19 新世界中的.NET大统一平台架构解析
    .NET平台系列16 .NET5/Asp.Net Core 在全球Web框架权威性能测试 Web Framework Benchmarks 中的吊炸天表现
    .NET平台系列15 .NET5的吊炸天性能改进
    .NET平台系列14 .NET5中的新增功能
    从零开始学Typescript-类型注解
    从零开始学Typescript-第一个TS程序
    从零开始学Typescript-安装Typescript
    从零开始学VUE-创建VUE应用
  • 原文地址:https://www.cnblogs.com/JSZX11556/p/4376571.html
Copyright © 2011-2022 走看看