【问题描述】
又到吃饭时间,Polo 面对饭堂里琳(fei)琅(chang)满(keng)目(die)的各种食品,
又陷入了痛苦的抉择中:该是吃手(jiao)打肉饼好呢,还是吃豆(cai)角(chong)肉片
好呢?嗯……又不是天秤座怎么会酱紫呢?
具体来说,一顿饭由 M 个不同的部分组成(荤菜,素菜,汤,甜品,饮料等
等),Polo 要在每个部分中选一种作为今天的午饭。俗话说的好,永远没有免费
的午餐,每种选择都需要有一定的花费。长者常常教导我们,便宜没好货,最便
宜的选择估计比较坑爹,可囊中羞涩的 Polo 还要把钱省下来给某人买生日礼物,
这该怎么办呢?
于是一个折中方案出来了:第 K 便宜的组合要花多少钱?这就要靠你了。
【输入】
第一行两个数 M,K,含义如上所述。
接下来 M 行,先是一个整数 Ai,表示第 i 个部分有多少种选择。接下来用
空格分开的 Ai 个整数表示每种选择的价格。
【输出】
一行一个整数表示答案。
【输入输出样例】
perdant.in perdant.out
2 2
2 1 3
2 2 2
3
【样例解释】
最便宜的选择是第一部分选择 1 块钱的,第二部分选择 2 块的。但由于第二
部分里 2 块钱有两种不同的选择,所以第二便宜的总花费仍然是 3 块。
【数据规模和约定】
10%的数据
M i
Ai
1
<=1000,M<=2。
30%的数据有 M<=2。
50%的数据有 K<=1000。
100%的数据有 Ai>0,
M i
Ai
1
<=500000,1<=M<=10,1<=K<=100000,1<=
价格<=10^8。

题解:

这个题目,考试的时候想到k短路,但k短路只会A星的做法,所以就愉快的爆空间了。然后开了同学的做法,首先可以二分一个答案,但是怎么check?可以dfs,但dfs写的太丑能只有50分,于是要加剪枝,如果当前的总花费已经大于了二分的答案就不要再搜了(十分显然),如果当前的合法(总数比二分的答案小)方案数已经大于了k,就可以返回了。

代码:

#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<algorithm>
#include<cstring>
#include<queue>
#define ll long long
using namespace std;
int m,k;
int cost[][],lenn[],flag=;
ll l=,r=,sum=; void check(int dep,ll rest){
if(dep==m+){
sum++;
return;
}
if(sum>=k) return;
for(int i=;i<=lenn[dep];i++){
if(cost[dep][i]>rest) return;
check(dep+,rest-cost[dep][i]);
}
}
int main(){
scanf("%d%d",&m,&k);
for(int i=;i<=m;i++){
scanf("%d",&lenn[i]);
for(int j=;j<=lenn[i];j++) scanf("%d",&cost[i][j]);
sort(cost[i]+,cost[i]+lenn[i]+);
l+=cost[i][],r+=cost[i][lenn[i]];
}
ll mid,ans;
while(l<=r){
mid=(l+r)/;
sum=;
check(,mid);
if(sum>=k) r=mid-,ans=mid;
else l=mid+;
}
printf("%lld",ans);
}

[JOJZ]3855.选择困难症的更多相关文章

  1. 选择困难症的福音——团队Scrum冲刺阶段-Day 1领航

    选择困难症的福音--团队Scrum冲刺阶段-Day 1领航 各个成员在 Alpha 阶段认领的任务 小组成员 分工 任务量 严域俊 完成小游戏接口部分.小游戏编写部分 21 吴恒佚 决策判断部分.小游 ...

  2. 选择困难症的福音——团队Scrum冲刺阶段-Day 2

    选择困难症的福音--团队Scrum冲刺阶段-Day 2 今日进展 编写提问部分 如何将不同的问题选项连接到不同的下一个问题 如何保证问题的链接不会弄丢 登陆注册界面 完成密码可见与不可见的更改 ui界 ...

  3. 选择困难症的福音——团队Scrum冲刺阶段-Day 3

    选择困难症的福音--团队Scrum冲刺阶段-Day 3 今日进展 编写提问部分 做了不同问题所对应的游戏选项,但关于游戏分类的界面还没有做完 登陆注册界面 更改ui界面,ui界面终于变好看了:) 学习 ...

  4. 选择困难症的福音——团队Scrum冲刺阶段-Day 4

    选择困难症的福音--团队Scrum冲刺阶段-Day 4 今日进展 编写提问部分 做了不同问题所对应的游戏选项,但关于游戏分类的界面还没有做完 增加功能 昨天在主界面增加"关于我们" ...

  5. 选择困难症的福音——团队Scrum冲刺阶段-Day5(补发 那天csshow)

    选择困难症的福音--团队Scrum冲刺阶段-Day 5 今日进展 编写提问部分 游戏分类的界面 将之前错误的图标改正 关于我们的俄罗斯方块,今天有了新的进展 NextBlockView(定义了下一个方 ...

  6. 选择困难症的福音——团队Scrum冲刺阶段-Day 7

    选择困难症的福音--团队Scrum冲刺阶段-Day 7 今日进展 测试代码 将界面设计完后放app使用示意图于此 今日贡献量 严域俊 吴恒佚 曾程 刘辰 邓煜坤 3.5 3.5 3.3 3.6 3 贡 ...

  7. 长沙理工大学第十二届ACM大赛-重现赛 L - 选择困难症

    题目描述 小L有严重的选择困难症. 早上起床后,需要花很长时间决定今天穿什么出门. 假设一共有k类物品需要搭配选择,每类物品的个数为Ai,每个物品有一个喜欢值Vj,代表小L对这件物品的喜欢程度. 小L ...

  8. 长沙理工大学第十二届ACM大赛L 选择困难症 (剪枝暴搜)

    链接:https://ac.nowcoder.com/acm/contest/1/L 来源:牛客网 选择困难症 时间限制:C/C++ 3秒,其他语言6秒 空间限制:C/C++ 131072K,其他语言 ...

  9. 微信小程序--帮助选择困难症者

    用户登录小程序成功后,通过传来的code获取openid,后端用的是PHP //获取code值换取openid public function code_weixin(Request $request ...

随机推荐

  1. 【Bit String Reordering UVALive - 6832 】【模拟】

    题意分析 题目讲的主要是给你一个01串,然后给你要变成的01串格式,问你要转换成这一格式最少需要移动的步数. 题目不难,但当时并没有AC,3个小时的个人赛1道没AC,归根到底是没有逼自己去想,又想的太 ...

  2. 【Offer】[60] 【n个骰子的点数】

    题目描述 思路分析 测试用例 Java代码 代码链接 题目描述 把n个骰子扔在地上,所有骰子朝上一面的点数之和为S.输入n,打印出s的所有可能的值出现的概率. [牛客网刷题地址]无 思路分析 递归的方 ...

  3. python自学Day02(自学书籍python编程从入门到实践)

    第三章 列表简介 3.1 列表是什么 按特定顺序排列的元素组成. 元素类型可以是任意数据类型. 元素之间没有任何的关系. 在python中用中括号 [] 括起来并用 ,号隔开 3.1.1 访问列表元素 ...

  4. 【LeetCode】406-根据身高重建队列

    title: 406-根据身高重建队列 date: 2019-04-15 21:13:06 categories: LeetCode tags: Java容器 比较器 贪心思想 题目描述 假设有打乱顺 ...

  5. springcloud超简单的入门2--Eureka服务治理

    Eureka服务治理 下面请听第一个话题,母...咳咳,拿错书了. Eureka简介 eureka是什么呢? 简单来说呢,当我的微服务应用多了起来,一个一个写死再程序里是件很不优雅的事情,而且同一服务 ...

  6. charles 重写工具/rewrite Srttings

    本文参考:charles 重写工具 rewrite Srttings 重写工具/rewrite Srttings and rewrite rule 功能:在通过charles时修改请求和响应 重写工具 ...

  7. 基于python-django框架的支付宝支付案例

    目录 @ 一. 开发前的准备 1. 必须了解的知识 SDK:软件开发工具包,可以为开发者提供快速开发的工具 沙箱环境:也就是测试环境 支付宝支付金额的精度:小数点后两位(面试) 支付宝用的什么加密方式 ...

  8. 指尖前端重构(React)技术调研分析

    摘要:重构前的技术文档调研与分析,包括技术选型为什么选择react,应用过程中的注意事项等. 一.为什么选择React React是当前前端应用最广泛的框架.三大SPA框架 Angular.React ...

  9. CF #579 (Div. 3) A.Circle of Students

    A. Circle of Students time limit per test2 seconds memory limit per test256 megabytes inputstandard ...

  10. JS的运动1(从简单到复杂运动,从单一属性到多属性同时进行的运动过程分析)

    js运动原理 运动基础 在js中,让一个元素动起来的最简单的方式,就是点击按钮,让元素移动.下面是一个简单的案例:(下面几个案例的的html和css都是采用这个为例) <!DOCTYPE htm ...