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的更多相关文章

  1. CSU1306:Manor(优先队列)

    Description Bob有n个正整数,他将这n个整数根据大小划分成两部分.对于小于等于k的整数放在集合A中,其余的放在集合B中.每次他从集合B中取出一个最大的值,将其变成0放入A集合中.然后将A ...

  2. csu 1306 Manor(优先队列)

    http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1306 1306: Manor Time Limit: 1 Sec  Memory Limit: 1 ...

  3. Manor

    Description Bob有n个正整数,他将这n个整数根据大小划分成两部分.对于小于等于k的整数放在集合A中,其余的放在集合B中.每次他从集合B中取出一个最大的值,将其变成0放入A集合中.然后将A ...

  4. .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 ...

  5. [Machine Learning] 国外程序员整理的机器学习资源大全

    本文汇编了一些机器学习领域的框架.库以及软件(按编程语言排序). 1. C++ 1.1 计算机视觉 CCV —基于C语言/提供缓存/核心的机器视觉库,新颖的机器视觉库 OpenCV—它提供C++, C ...

  6. .Net开源Excel、Word操作组件-NPOI、EPPlus、DocX[转]

    link: http://www.cnblogs.com/jacktang/p/4493760.html 一.NPOI 简介:NPOI is the .NET version of POI Java ...

  7. MVC WebAPI 三层分布式框架开发

    版权声明:本文为博主原创文章,未经博主允许不得转载. 前言:SOA(面向服务的架构)是目前企业应用开发过程中普遍采用的技术,基于MVC WebAPI三层分布式框架开发,以此适用于企业信息系统的业务处理 ...

  8. <转>JDBC获取DB元数据

    原文链接:http://jiauwu.iteye.com/blog/1307617 package com.util.jdbc; import java.sql.Connection; import ...

  9. [转载]SOAPUI压力测试的参数配置

    原文地址:SOAPUI压力测试的参数配置作者:goooooodlife The different Load Strategies available in soapUI and soapUI Pro ...

随机推荐

  1. c++builder 重载WindowProc、WndProc 截获消息(比Delphi多一个Message Map方法)

    c++builder 重载WindowProc.WndProc 截获消息 方法一WindowProc void __fastcall  myWindowProc(Messages::TMessage ...

  2. 部署vc2008开发的程序(vcredist_x86是其中一个办法)

    如果你编译了一个VC2008的默认的CRT/MFC的应用程序,如果目标部署电脑上没有安装相应的VC2008的动态库,当运行你的程序的时 个,会出现如下错误信息.   这是因为程序使用了基于VC2008 ...

  3. HDU 1787 GCD Again

    题目大意:求小于n的gcd(i,n)大于1的个数: 题解:欧拉函数直接求gcd(i,n)==1的个数  用n减即可 #include <cstdio> int eular(int n){ ...

  4. C#中继承,集合(Eleventh day)

    又到了总结知识的时间,今天在云和学院继续学习了继承的一些运用,和集合的运用.下面就总结下来吧 理论: 显示调用父类的构造方法,关键字: base:构造函数不能被继承:子类对象被实例化的时候会先去主动的 ...

  5. objective-C学习笔记(二)类 class 和 结构 struct

    Objective-C的类型 引用类型 类 class 指针 pointer 块 block 值类型 基础数值类型 结构 struct 枚举 enum 类型装饰 协议 protocol 类别 cate ...

  6. chown命令详解

    chown将指定文件的拥有者改为指定的用户或组,用户可以是用户名或者用户ID:组可以是组名或者组ID:文件是以空格分开的要改变权限的文件列表,支持通配符.系统管理员经常使用chown命令,在将文件拷贝 ...

  7. VM VirtualBox安装Centos6.5

    · · 参考资料:http://www.jb51.net/os/239738.html 如果安装图形界面,内存分配要大于628M 和下图安装选项无关,1.2都可以 界面说明: Install or u ...

  8. leetcode 15. 3Sum 双指针

    题目链接 给n个数, 找出三个数相加结果为0的所有的组, 不可重复. 用双指针的思想,O(n^2)暴力的找, 注意判重复. class Solution { public: vector<vec ...

  9. Flask中路由模块的实现

    在Flask中的路由功能主要通过修饰函数route实现,下面我们就来挖掘下route在源代码中是怎么分配视图函数的. def route(self, rule, **options): def dec ...

  10. 转:不会定义jQuery插件,不要说会jQuery

    一:导言 有些WEB开发者,会引用一个JQuery类库,然后在网页上写一写$("#"),$("."),写了几年就对别人说非常熟悉JQuery.我曾经也是这样的人 ...