csu1306: Manor
http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1306
解题思路:唬人的水题,只要按照他的意思打,就能过,不过,数组最好开大点。用到优先队列,也可以用栈来处理。
总元素就只有N个,再怎么挪,总个数也不会变化。处理的时候B中的值虽说要加b,但是,不管加成什么样子,最后要放到A里面去的时候还是要变成0,完全不用管它的值有多大。A里面的元素,有要进来的(都是0),有要出去的(大于K),还要每次加a。
所以,我们可以只处理A中得元素,【B中元素的个数】=n-【A中元素个数】。每次处理的时候,要是B中还有元素n-【A中元素个数】>0,就从B中取个元素处理后放到A中(其实就是往A中放个0,因为不管原数是多少,最后都是变成0放进去)。
对于A中得数,每次处理都要加a。要是每次处理都给A中的数全加a,耗时较多。而且,A中得数的值只在判断是否大于k是有效。所以,我们可以用优先队列存储A中的数。每次处理,就拿出队头元素,把它加上从开始处理到现在要加的值(i*a(第i次处理))再判断即可。要是队头元素加上i*a>k,则弹出即可。
对于压入队列的“0”,不要直接压“0”,要处理。压入队的,应该是“相对0”,对于现在,队中所有元素加的a的情况来说,是“0"的值,即“-a*(i-1)”。因为后面轮到它加时,要加i个a,而在它进来的前面的那些要加的a,它不该加,所以要提前“减掉”。
对于处理操作次数时,不能每输入一个数都重头操作一次。我们只要记住【最大的操作次数】,然后把数据从原始数据操作【最大的操作次数】次,其中记录每次操作前的A中的元素的个数即可。最后,只要按照输入的操作次数的顺序输出相关值即可。
| 40227 | 20114045007 | Accepted |
2056
|
288
|
C++/Edit | 924 B | 2013-09-02 11:10:07 |
#include<stdio.h>
#include<queue>
#include<algorithm>
using namespace std;
int main()
{
int n,k,a,b;
int i,j;
int q,m[205]; //询问次数和询问的情况
int size[405];//A中元素的个数
int f,max1; //输入的原数,询问中处理次数最多的那个次数
while(scanf("%d%d%d%d",&n,&k,&a,&b)!=EOF)
{
max1=0;
priority_queue<int> pq; //优先队列,存储A中数的情况
for(i=0;i<n;i++)
{
scanf("%d",&f);
if(f<=k)pq.push(f); //要是输入的原数情况,小于等于k的放入A中
}
scanf("%d",&q);
for(i=0;i<q;i++) //输入询问情况
{
scanf("%d",&m[i]);
max1=max(max1,m[i]); //记录询问中最大操作次数
}
for(i=1;i<=max1;i++)
{
size[i]=pq.size(); //第i次操作前A中元素个数,【B中元素个数】 = n - 【A中元素个数】
if(n-pq.size()>0)pq.push((i-1)*a*(-1));//B中没有元素的话,就不取;否则取一个"0",加到A中,由于A中所有元素后面都要加i'*a,此时已经加了i*a,所以放进去的元素值应该是
(i-1)*a*(-1)
while(!pq.empty()&&pq.top()+a*i>k)pq.pop(); //若A中的值加了i*a后大于K,则直接弹出(相当于放入B中)) } for(i=0;i<q;i++) printf("%d\n",n-size[m[i]]); //输出第i次操作前B中元素个数 } return 0;}
csu1306: Manor的更多相关文章
- CSU1306:Manor(优先队列)
Description Bob有n个正整数,他将这n个整数根据大小划分成两部分.对于小于等于k的整数放在集合A中,其余的放在集合B中.每次他从集合B中取出一个最大的值,将其变成0放入A集合中.然后将A ...
- csu 1306 Manor(优先队列)
http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1306 1306: Manor Time Limit: 1 Sec Memory Limit: 1 ...
- Manor
Description Bob有n个正整数,他将这n个整数根据大小划分成两部分.对于小于等于k的整数放在集合A中,其余的放在集合B中.每次他从集合B中取出一个最大的值,将其变成0放入A集合中.然后将A ...
- .Net开源Excel、Word操作组件-NPOI、EPPlus、DocX
一.NPOI 简介: NPOI is the .NET version of POI Java project. With NPOI, you can read/write Office 2003/2 ...
- [Machine Learning] 国外程序员整理的机器学习资源大全
本文汇编了一些机器学习领域的框架.库以及软件(按编程语言排序). 1. C++ 1.1 计算机视觉 CCV —基于C语言/提供缓存/核心的机器视觉库,新颖的机器视觉库 OpenCV—它提供C++, C ...
- .Net开源Excel、Word操作组件-NPOI、EPPlus、DocX[转]
link: http://www.cnblogs.com/jacktang/p/4493760.html 一.NPOI 简介:NPOI is the .NET version of POI Java ...
- MVC WebAPI 三层分布式框架开发
版权声明:本文为博主原创文章,未经博主允许不得转载. 前言:SOA(面向服务的架构)是目前企业应用开发过程中普遍采用的技术,基于MVC WebAPI三层分布式框架开发,以此适用于企业信息系统的业务处理 ...
- <转>JDBC获取DB元数据
原文链接:http://jiauwu.iteye.com/blog/1307617 package com.util.jdbc; import java.sql.Connection; import ...
- [转载]SOAPUI压力测试的参数配置
原文地址:SOAPUI压力测试的参数配置作者:goooooodlife The different Load Strategies available in soapUI and soapUI Pro ...
随机推荐
- Python中type与Object的区别
Python中type与Object的区别 在查看了Python的API后,总算明白了.现在总结如下: 先来看object的说明: Python中关于object的说明很少,甚至只有一句话: clas ...
- HDU 3360 National Treasures
题目大意:大厅每个位置都有一个文物或者一个守卫,文物是安全的前提是: 关键位置上必须有一个守卫,或者文物本身的位置上有一个守卫.求保证每个文物是安全的守卫的最少数量. #include <cst ...
- windows XP 安装pip
1.首先安装Python 2.添加环境变量 我的是 path = C:\Python27 3.下载setuptools 这里可参考这篇博文,附带资源的:http://blog.csdn.net/sud ...
- IT 名企招聘信息
[搜狗]网页搜索抓取与挖掘组诚聘实习生 工作方向: 抓取架构方向. 职位要求 1.对互联网和搜索引擎技术有浓厚兴趣: 2.熟练使用c .熟悉Linux开发环境.熟悉shell.python.awk等 ...
- phpmyadmin出现空password登录被禁止
在Windows或者Linux下mysql安装后默认的password为空,又当我们又安装了mysql的管理工具 phpmyadmin后登陆时出现"空password登陆呗禁止(參见同意pa ...
- Android UI 之一步步教你自定义控件(自定义属性、合理设计onMeasure、合理设计onDraw等)
Android开发做到了一定程度,多少都会用到自定义控件,一方面是更加灵活,另一方面在大数据量的情况下自定义控件的效率比写布局文件更高. 一个相对完善的自定义控件在布局文件中和java ...
- 跨域引入iframe 自适应高度
最近和别的公司合作一个项目,需要从他们那边引入一个页面,刚开始想的挺简单的,用iframe 引入就好啦,可是操作中才发现,自适应的问题不好解决,试了挺多办法,最终找到一个比较好的方法,记录一下,留着备 ...
- C#基础面试
1. 简述Private.Protected.Public.Internal 等访问修饰符的访问权限问题 Private:私有成员,只有类的内部成员可以访问 Protected:保护成员,在类的内部和 ...
- SSIS CDC(Change Data Capture)组件在数据库中启用报错。 The error returned was 14234: 'The specified '@server' is invalid
昨天实验CDC,在数据库中执行以下语句的时候出错. EXEC sys.sp_cdc_enable_table @source_schema = N'stg', @source_name = N'CDC ...
- C# Coding & Naming Conventions
Reference document https://msdn.microsoft.com/en-us/library/ff926074.aspx https://msdn.microsoft.com ...