BZOJ3874:[AHOI2014&JSOI2014]宅男计划(爬山法)
Description
Input
Output
输出仅包含一行一个整数表示JYY可以宅的最多的天数。
Sample Input
5 0
10 2
Sample Output
HINT
【样例说明】
Solution
首先我们可以先将食物sort一下然后去重,使之成为一个价格递增且保质期递增的数列
被我们从食物中舍弃的肯定都是原序列中有比它更优的
然后我们可以发现,对于确定的点外卖次数,我们可以通过贪心法来求更多生存天数
具体贪心方法是对于我们要订的t次外卖,如果食物i(1<=i<=n)能订的话那显然比i+1更优,
不超保质期的情况下优先用i把t次订单填满。
把订外卖次数当成x轴,然后就可以用模拟退火乱搞了
然而搞来搞去只有九十,我们发现答案始终比正确答案小一点怎么办呢?
由于购买次数少的时候买的东西贵,购买次数多的时候配送费贵,
我们可以大胆猜测结果单峰然后把源程序注释掉一点就能过了
Code
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<cstdio>
#include<ctime>
#include<cmath>
#include<algorithm>
using namespace std; struct Node{long long cost,life;}Food[];
bool cmp(Node a,Node b){return a.cost<b.cost || a.cost==b.cost && a.life>b.life;} long long M,F,N,cnt,ans; double Rand(){return rand()%/10000.0;} long long Calc(long long t)
{
long long Left=M-t*F,sum=;
for (int i=; i<=N; ++i)
{
if (Left*1.0/Food[i].cost/t>=(Food[i].life-Food[i-].life+(i==)))
{
Left-=Food[i].cost*(Food[i].life-Food[i-].life+(i==))*t;
sum+=(Food[i].life-Food[i-].life+(i==))*t;
continue;
}
else
{
sum+=Left/Food[i].cost;
break;
}
}
if (sum>ans) ans=sum;
return sum;
} void Simulate_Anneal()
{
double T=M/F+;
long long now=;
while (T>=)
{
long long nxt=now+T*(*Rand()-);
while (nxt<=) nxt=T*Rand();
nxt%=(M/F+); long long delta=Calc(nxt)-Calc(now);
if (delta>/*|| exp(delta/T)>Rand()*/)
now=nxt;
T*=0.93;
}
} int main()
{
scanf("%lld%lld%lld",&M,&F,&N);
for (int i=; i<=N; ++i)
scanf("%lld%lld",&Food[i].cost,&Food[i].life);
sort(Food+,Food+N+,cmp);
for (int i=; i<=N; ++i)
if (Food[i].life<=Food[i-].life)
{
for (int j=i; j<=N; ++j)Food[j]=Food[j+];
N--; i--;
}
for (int i=; i<=; ++i)
Simulate_Anneal();
printf("%lld",ans);
}
BZOJ3874:[AHOI2014&JSOI2014]宅男计划(爬山法)的更多相关文章
- [luogu] P4040 [AHOI2014/JSOI2014]宅男计划(贪心)
P4040 [AHOI2014/JSOI2014]宅男计划 题目背景 自从迷上了拼图,JYY就变成了个彻底的宅男.为了解决温饱问题,JYY不得不依靠叫外卖来维持生计. 题目描述 外卖店一共有N种食物, ...
- Bzoj 3874: [Ahoi2014&Jsoi2014]宅男计划 三分+贪心
3874: [Ahoi2014&Jsoi2014]宅男计划 Time Limit: 1 Sec Memory Limit: 256 MBSubmit: 861 Solved: 336[Su ...
- bzoj 3874: [Ahoi2014&Jsoi2014]宅男计划
Description 外卖店一共有N种食物,分别有1到N编号.第i种食物有固定的价钱Pi和保质期Si.第i种食物会在Si天后过期.JYY是不会吃过期食物的. 比如JYY如果今天点了一份保质期为1天的 ...
- food(洛谷P4040 [AHOI2014/JSOI2014]宅男计划)
题目在这里 题目描述 外卖店一共有N种食物,分别有1到N编号.第i种食物有固定的价钱Pi和保质期Si.第i种食物会在Si天后过期.JYY是不会吃过期食物的. 比如JYY如果今天点了一份保质期为1天的食 ...
- Luogu P4040 [AHOI2014/JSOI2014]宅男计划
题目 显然存活天数与叫外卖次数的函数是凸函数. 所以三分买外卖的次数. 然后把食品按保质期升序排序. 并且单调栈搞一下,把又贵又保质期短的丢掉. 那么随着保质期的增加,食品的价格一定上涨. 所以我们从 ...
- 洛谷$P4040\ [AHOI2014/JSOI2014]$宅男计划 贪心
正解:三分+贪心 解题报告: 传送门$QwQ$ 其实很久以前的寒假就考过了,,,但那时候$gql$没有好好落实,就只写了个二分,并没有二分套三分,就只拿到了$70pts$ #include <b ...
- 【BZOJ3874】[AHOI&JSOI2014]宅男计划(贪心,三分)
[BZOJ3874][AHOI&JSOI2014]宅男计划(贪心,三分) 题面 BZOJ 洛谷 题解 大力猜想一最长的天数和购买外卖的总次数是单峰的.感性理解一下就是买\(0\)次是\(0\) ...
- Luogu4040 AHOI/JSOI2014 宅男计划 贪心、二分、三分
传送门 仍然对"为什么这个函数单峰"的问题毫无理解 首先,对于保质期又低.价格又贵的食物,我们显然不需要购买它.所以如果设\(pri_i\)表示保质期不小于\(i\)的所有食品中价 ...
- bzoj3874&2832 [Ahoi2014]宅男计划 模拟退火,三分
[Ahoi2014&Jsoi2014]宅男计划 Time Limit: 1 Sec Memory Limit: 256 MBSubmit: 962 Solved: 371[Submit][ ...
随机推荐
- PIE SDK分类合并
1. 算法功能简介 分类合并功能是将分类文件中所设置的对应类别进行合并. PIE SDK支持算法功能的执行,下面对分类合并算法功能进行介绍. 2. 算法功能实现说明 2.1. 实现步骤 第一步 算法参 ...
- 利用Flume将本地文件数据中收集到HDFS
1. 创建文件 放入一个txt文件 然后查看hdfs上的文件夹 不知道为什么并没有出现本地的文件 也不报错 后来发现,没有在logs文件夹下面,在newlogs文件夹下面
- 配intelliJ IDEA 过程
1.安装svn 选项全选择,命令行执行要选择上2.安装java jdk 配jdk环境变量3.安装intelliJ IDEA 地址:http://idea.imsxm.com4.注册intelliJ I ...
- unity烘焙记录
1.Unity Android 阴影不显示.阴影显示不正确 解决 http://blog.csdn.net/xuetao0605/article/details/50626181 2.阴影强度问题 不 ...
- 【VirtualBox】快照
一.快照备份 虚拟机系统快照下来,以后就可以恢复到快照之前的系统 右上角->虚拟电脑工具->快照
- Maven入门之简介与安装
一.Maven简介 1.什么是Maven? Maven是一个项目管理工具和集成编译工具,它主要包含如下内容: –一个项目对象模型(Project Object Model), –一组标准集合, –一个 ...
- 【U1结业机试题】新闻内容管理系统:解析XML文件读取Html模版生成网页文件
一.作业要求: 1.在xml文件中创建新闻节点news,包含标题.作者.日期.正文等信息 2.创建HTML模板文件 3.读取xml中所有新闻信息,并使用新闻信息替换模板文件中占位符,从而为每一条新闻生 ...
- 【Java集合】LinkedList详解前篇
[Java集合]LinkedList详解前篇 一.背景 最近在看一本<Redis深度历险>的书籍,书中第二节讲了Redis的5种数据结构,其中看到redis的list结构时,作者提到red ...
- ACM-线段树
http://blog.csdn.net/libin56842/article/details/8530197 基础可以看上面这篇文章 风格: maxn是题目给的最大区间,而节点数要开4倍,确切的说… ...
- 初学orcale(一)
Oracle数据库学习: 01.数据库简介: (1)文件型数据库: Access Office组件: Foxpro (2)NoSql数据库(泛指非关系型数据库): NoSQL(NoSQL = Not ...