HUNAN 11560 Yangyang loves AC(二分+贪心)

http://acm.hunnu.edu.cn/online/?action=problem&type=show&id=11560&courseid=0

题意:总共有n天,每天yangyang都需要一个快乐值,有m个队友,每个队友都会给阳阳一个快乐值(为2的幂),并且只能给一次,如果某一天队友给的快乐值达到yangyang需要的快乐值那么这一天yangyang就是快乐的,统计最多快乐的天数。

思路:因为达到快乐的天数不要求连续,那么只要对需要的快乐值和队友给的快乐值分别排序,然后每次二分出一个快乐的天数x,判断能不能用m个数去满足它,所以把0到x的数加入优先队列,然后从m开始从大到小去覆盖优先队列的值.

 1 #include<cstdio>
 2 #include<queue>
 3 #include<algorithm>
 4 using namespace std;
 5 
 6 int n,m,h[20010],p[20010];
 7 
 8 bool ok(int x)
 9 {
10     priority_queue<int>que;
11     for(int i=0;i<x;i++)
12         que.push(h[i]);
13     int y=m;
14     while(!que.empty())
15     {
16         y--;
17         if(y<0) break;
18         if(p[y]<que.top()) que.push(que.top()-p[y]);
19         que.pop();
20     }
21     return que.empty();
22 }
23 void solve()
24 {
25     int lb=0,ub=n;
26     int cnt=0;
27     while(lb<=ub)
28     {
29         int mid=(lb+ub)>>1;
30         if(ok(mid))
31         {
32             lb=mid+1;
33             cnt=max(cnt,mid);
34            // printf("%d %d\n",cnt,lb);
35         }
36         else ub=mid-1;
37     }
38     printf("%d\n",cnt);
39 }
40 int main()
41 {
42     //freopen("a.txt","r",stdin);
43     while(~scanf("%d%d",&n,&m))
44     {
45         for(int i=0;i<n;i++) scanf("%d",&h[i]);
46         for(int i=0;i<m;i++) scanf("%d",&p[i]);
47         sort(h,h+n);
48         sort(p,p+m);
49         solve();
50     }
51     return 0;
52 }

 

转载于:https://www.cnblogs.com/nowandforever/p/4728290.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/397691.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

BrowserSync开发利器

2019独角兽企业重金招聘Python工程师标准>>> 大大节省开发时间。安装使用简单。使用步骤&#xff1a; 1、nodejs环境 安装 2、在项目中使用npm安装到本项目 3、对要监听的文件执行响应命令 官网更详细&#xff1a;http://www.browsersync.cn/#install 原理&#xf…

python字符串解析_Python-字符串解析-正则-re

正则表达式特殊字符序列&#xff0c;匹配检索和替换文本普通字符 特殊字符 数量&#xff0c;普通字符用来定边界更改字符思路字符串函数 > 正则 > for循环元字符  匹配一个字符# 元字符大写&#xff0c;一般都是取小写的反1. 0~9 整数          \d    …

algorithm -- 选择排序

选择排序是《导论》第一章课后习题&#xff0c;仿照插入排序&#xff0c;再次运用循环不变式来证明下算法的正确性&#xff0c;C 源码&#xff1a; // 交换函数 void swap( int& a, int& b ) {a a^b;b a^b;a a^b; } void selectSort( int *arr, int count ) {if( a…

OD 完美走位

题目描述&#xff1a; 在第一人称射击游戏中&#xff0c;玩家通过键盘的A、S、D、W四个按键控制游戏人物分别向左、向后、向右、向前进行移动&#xff0c;从而完成走位。假设玩家每按动一次键盘&#xff0c;游戏人物会向某个方向移动一步&#xff0c;如果玩家在操作一定次数的键…

layui upload 后台获取不到值

后台获取不到值方法一&#xff1a; <script>layui.use(upload, function () {var upload layui.upload;//执行实例var uploadInst upload.render({elem: #test1 //绑定元素, url: /Home/UploadFiles //上传接口, field: "fileNames" //添加这个属性与后台…

ueeditor无法上传图片_百度ue文本编辑器开发中无法上传图片

第一次发文&#xff0c;好紧张呀&#xff0c;不知道会不会没人看。之前用ue遇到了一些坑&#xff0c;没人看就当自己记录了笔记。第一次用&#xff0c;总是会遇到问题&#xff0c;可以先查看下百度ue的演示http://ueditor.baidu.com/website/onlinedemo.html和API http://fex.b…

SQL 语句优化--IN语句优化案例

为什么80%的码农都做不了架构师&#xff1f;>>> 今天客户系统升级&#xff0c;通过DMVs性能分析查了一下&#xff0c;升级后发现一个语句执行时间比较长&#xff0c;执行语句要好几秒钟&#xff0c;调出语句如下&#xff1a; select distinct field003 from ufi2j0…

Activity跳转

本例中MainActivity为&#xff1a;FirstActivity.java FirstActivity如下&#xff1a; package com.wyl.intentmultiactivitytest;import android.app.Activity; import android.content.Intent; import android.os.Bundle; import android.view.View; import android.view.Vie…

Java课程设计---项目数据库设计(含实体类)

1、数据库分析设计 将数据库命名为&#xff1a;db_student 分析系统中各角色之间的关系 2、表设计 &#xff08;1&#xff09;新建表tb_student&#xff08;学生表&#xff09; &#xff08;2&#xff09;新建表tb_admin&#xff08;管理员表&#xff09; &#xff08;3&#x…

java)_Java NIO系列教程(一) Java NIO 概述

原文链接 作者&#xff1a;Jakob Jenkov 译者&#xff1a;airu 校对&#xff1a;丁一Java NIO 由以下几个核心部分组成&#xff1a;ChannelsBuffersSelectors虽然Java NIO 中除此之外还有很多类和组件&#xff0c;但在我看来&#xff0c;Channel&#xff0c;Buffer…

本地读取服务器Xml文件及本地读本地的xml

updateUrl"ServerUrl"(服务器路径) WebClient wc new WebClient(); Stream stream wc.OpenRead(updateUrl); XmlDocument xmlDoc new XmlDocument(); xmlDoc.Load(stream); XmlNode list xmlDoc.SelectSingleNode("Update"); foreach (XmlNode node in…

Context.getExternalFilesDir()和Context.getExternalCacheDir()方法

2019独角兽企业重金招聘Python工程师标准>>> Context.getExternalCacheDir()方法可以获取到 SDCard/Android/data/你的应用包名/cache/目录&#xff0c;一般存放临时缓存数据如果使用上面的方法&#xff0c;当你的应用在被用户卸载后&#xff0c;SDCard/Android/dat…

java 静态代码块_JAVA静态代码块

今天遇到下面的代码&#xff0c;感觉很奇怪&#xff0c;特意记录下&#xff1a;代码如下&#xff1a;public class Test {private static List objs new ArrayList();static {objs.add(new Test(Test.S_NAME,Test.NAME,Test.COUNT));objs.add(new Test(Test.S_NAME,Test.NAME,…

context详解

1、Context概念&#xff1a; Context&#xff0c;相信不管是第一天开发Android&#xff0c;还是开发Android的各种老鸟&#xff0c;对于Context的使用一定不陌生~~你在加载资源、启动一个新的Activity、获取系统服务、获取内部文件&#xff08;夹&#xff09;路径、创建View操作…

Unity Camera的两种模式

http://www.cnblogs.com/zhaoqingqing/p/3302484.html

mysql之group_concat函数

mysql之group_concat函数 在介绍GROUP_CONCAT之前&#xff0c;我们先来看看concat()函数和concat_ws()函数。 先准备一个测试数据库&#xff1a; mysql> select * from scores; --------------------- | id | name | score | --------------------- | 1 | zhangsan | 1…

java 图片批量上传_java实现批量上传图片,还要保证每个图片的顺序号,疑问求教!...

rt我要一次性同时上传n张照片&#xff0c;并且每张照片的顺序号还不一样&#xff0c;第一张的serialno是1&#xff0c;第二张是2。。一开始我做单张图片上传&#xff0c;代码如下RequestMapping("/picUpLoad")ResponseBodypublic Map picUpLoad(MultipartFile file, …

linux 用户创建、管理、权限分配

&#xff08;1&#xff09;su与sudo su:通过su可以在用户之间切换&#xff0c;如果超级权限用户root向普通或虚拟用户切换不需要密码&#xff0c;什么是权力&#xff1f;这就是&#xff01;而普通用户切换到其它任何用户都需要密码验证&#xff1b; sudo: sudo扮演的角色注定了…

WebApi路由

路由分为两种模式&#xff1a;模板路由和特性路由。 模板路由&#xff1a; 模板路由是ASP.NET Web API默认提供的路由。模板路由使用前需要定义路由模板。如下面默认的路由模板&#xff1a; 默认路由的URL格式是api/{controller}/{id}。api代表在资源前面要带上api目录&#xf…

HW--漂亮度2(测试通过)

总结&#xff1a;几个函数的使用 &#xff08;1&#xff09; int numInteger.parseInt(str[0]); //将第一个字符串转成整形数&#xff0c;表示名字个数 &#xff08;2&#xff09; String string1str[i].toLowerCase(); //变小写都 &#xff08;3&#xff09; char ch[]strin…