洛谷P1021邮票面值设计 [noip1999] dp+搜索
正解: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+搜索的更多相关文章
- 洛谷P1021 邮票面值设计
题目描述 给定一个信封,最多只允许粘贴N张邮票,计算在给定K(N+K≤15)种邮票的情况下(假定所有的邮票数量都足够),如何设计邮票的面值,能得到最大值MAX,使在1-MAX之间的每一个邮资值都能得到 ...
- 洛谷 P1021 邮票面值设计
题目描述 给定一个信封,最多只允许粘贴N张邮票,计算在给定K(N+K≤15)种邮票的情况下(假定所有的邮票数量都足够),如何设计邮票的面值,能得到最大值MAX,使在1-MAX之间的每一个邮资值都能得到 ...
- 洛谷——P1021 邮票面值设计
https://www.luogu.org/problem/show?pid=1021 题目描述 给定一个信封,最多只允许粘贴N张邮票,计算在给定K(N+K≤15)种邮票的情况下(假定所有的邮票数量都 ...
- 洛谷P1021邮票面值设计
题目 一道很经典的搜索题,可以锻炼搜索的能力,比如可以用dfs覆盖加dp的方式来寻找+更新答案.而且还可以通过在递归中增加数组的方式来辅助搜索. #include <bits/stdc++.h& ...
- P1021 邮票面值设计(dfs+背包dp)
P1021 邮票面值设计 题目传送门 题意: 给定一个信封,最多只允许粘贴N张邮票,计算在给定K(N+K≤15N+K≤15)种邮票的情况下 (假定所有的邮票数量都足够),如何设计邮票的面值,能得到最大 ...
- P1021 邮票面值设计
P1021 邮票面值设计 题目描述 给定一个信封,最多只允许粘贴N张邮票,计算在给定K(N+K≤15)种邮票的情况下(假定所有的邮票数量都足够),如何设计邮票的面值,能得到最大值MAX,使在1-MAX ...
- P1021 邮票面值设计——搜索+完全背包
P1021 邮票面值设计 题目意思是你最多用n张邮票,你可以自己设定k种邮票的面值,每种邮票数量无穷,你最多能用这k种邮票在不超过n张的情况下,组合成的价值要求是从1开始连续的, 求最大能连续到多少: ...
- [NOIP1999提高] CODEVS 1047 邮票面值设计(dfs+dp)
dfs出邮票的各种面值,然后dp求解. ------------------------------------------------------------------------------- ...
- 洛谷 P2725 邮票 Stamps Label:DP
题目背景 给一组 N 枚邮票的面值集合(如,{1 分,3 分})和一个上限 K —— 表示信封上能够贴 K 张邮票.计算从 1 到 M 的最大连续可贴出的邮资. 题目描述 例如,假设有 1 分和 3 ...
随机推荐
- IoC之AutoFac(四)——AutoFac在MVC中的使用
阅读目录 Mvc中使用Autofac 第一步:在mvc中添加dll文件,可以通过Nuget直接添加 第二步:在App_Start文件夹中添加一个AutofacConfig类 第三步:在Global.a ...
- Effective Java 第三版——81. 优先使用并发实用程序替代wait和notify
Tips 书中的源代码地址:https://github.com/jbloch/effective-java-3e-source-code 注意,书中的有些代码里方法是基于Java 9 API中的,所 ...
- Python时间,日期,时间戳之间转换,时间转换时间戳,Python时间戳转换时间,Python时间转换时间戳
#1.将字符串的时间转换为时间戳方法: a = "2013-10-10 23:40:00" #将其转换为时间数组 import time timeArray = time.strp ...
- Vmware 虚拟机无法启动
问题背景: 自己的电脑坏了,用的事小伙伴的电脑,安装VMware 软件,然后创建虚拟机(放在移动硬盘上).在操作虚拟主机的时候,中间不小心碰到了移动硬盘, 然后移动硬盘就掉线了.这个时候再去启动虚拟主 ...
- Android Studio 好用的设置
Android Studio 好用的设置 设置目录 Getter 模板修改--自动处理 null 判断 格式化代码自动整理方法位置--广度 or 深度 设置步骤: Getter 模板修改,自动处理 n ...
- go 源码学习之---Tail 源码分析
已经有两个月没有写博客了,也有好几个月没有看go相关的内容了,由于工作原因最近在做java以及大数据相关的内容,导致最近工作较忙,博客停止了更新,正好想捡起之前go的东西,所以找了一个源码学习 这个也 ...
- Hibernate获取数据java.lang.StackOverflowError
原因:因为在重写toString()方法时,把关联的属性也放入到toString方法中了,去掉就可以了. 如:重写的toString方法中不能有关联关系IDCard属性idCard public cl ...
- Build GMP on 64bit Windows
1.MSYS2 环境搭建 1.1.安装 msys2 的主页地址: http://www.msys2.org/ 下载32位或64位,我这里 下载了64位 msys2-x86_64-20161025.ex ...
- js 可拖动div 调整大小
dragBorder: function (parent, right, bottom, bottomRight) { var isDownRight = false; var isDownBotto ...
- 大话前端解析Json对象
一.对于标准的json对象如: var result=[{"flag":1,"macId":"2","mbId":0,& ...