KPI

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 1160    Accepted Submission(s): 488

Problem Description
你工作以后, KPI 就是你的全部了. 我开发了一个服务,取得了很大的知名度。数十亿的请求被推到一个大管道后同时服务从管头拉取请求。让我们来定义每个请求都有一个重要值。我的KPI是由当前管道内请求的重要值的中间值来计算。现在给你服务记录,有时我想知道当前管道内请求的重要值得中间值。
 
Input
有大约100组数据。

每组数据第一行有一个n(1≤n≤10000)

,代表服务记录数。

接下来有n行,每一行有3种形式
  "in x": 代表重要值为x(0≤x≤109)

的请求被推进管道。
  "out": 代表服务拉取了管道头部的请求。
  "query: 代表我想知道当前管道内请求重要值的中间值. 那就是说,如果当前管道内有m条请求, 我想知道,升序排序后第floor(m/2)+1th

条请求的重要值.

为了让题目简单,所有的x都不同,并且如果管道内没有值,就不会有"out"和"query"操作。

 
Output
对于每组数据,先输出一行

Case #i:
然后每一次"query",输出当前管道内重要值的中间值。

 
Sample Input
6
in 874
query
out
in 24622
in 12194
query
 
Sample Output
Case #1:
874
24622
 
Source
题意: 三种操作 ”in  x“ 将x 加入到队列
                      ”out“ 删除队头元素
                      ”query“ 队列中现有元素升序排列后 输出第 ( len/2+1) 大元素
题解:1.将所有元素离散化处理 这里的方法比较麻烦 具体看代码有多次映射
         2.根据操作  将离散化后的元素加入 树状数组 in~add(x,1),out~add(x,-1);
         3.树状数组求第k大 
         f[n] 树状数组
         f[1]=a1
         f[2]=a1+a2
         f[3]=a3
 
 #include<iostream>
#include<cstring>
#include<cstdio>
#include<map>
#include<algorithm>
#include<stack>
#include<queue>
using namespace std;
struct node
{
int x;
int y;
} s[];
int t;
int jishu=;
char a[][];
int b[];
int exm;
int f[];
int coun=;
map<int,int> mp;
map<int,int> mpp;
queue<int> st;
int n;
bool cmp(struct node aa,struct node bb )
{
return aa.x<bb.x;
}
void add(int x,int y,int n)
{
for (;x<=n;x+=x&(-x)) f[x]+=y;
}
int sum(int x)
{
int ret=;
for (;x;x-=x&(-x)) ret+=f[x];
return ret;
}
int find_k(int k) //求第k大 板子
{
int i,w=;
for (i=;i>=;i--)
if (w+(<<i)<=n&&f[w+(<<i)]<k)
{
k-=f[w+(<<i)];w+=<<i;
}
return w+;
}
int k_num(int k){
int w=,cnt=;
for(int i=;i>=;i--)
{ w+=(<<i);
if(w>n || k<=f[w])
w-=(<<i);
else
{
k-=f[w];
}
}
return w+;
}
int main()
{
while(scanf("%d",&t)!=EOF)
{ jishu++;
memset(s,,sizeof(s));
memset(a,,sizeof(a));
memset(b,,sizeof(b));
memset(f,,sizeof(f));
mp.clear();
mpp.clear();
while(st.size()>)
st.pop();
coun=;
for(int i=;i<=t;i++)
{
scanf("%s",&a[i]);
if(a[i][]=='i')
{
scanf("%d",&exm);
s[++coun].x=exm;//存插入的元素
s[coun].y=coun;//struct 存储对应位置
}
}
cout<<"Case #"<<jishu<<":"<<endl;
sort(s+,s++coun,cmp);//结构体排序 x为主键升序排列
b[s[].y]=;
int k=;
mp[s[].x]=;
mpp[]=s[].x;
for(int i=;i<=coun;i++)//for循环完成离散化处理
{
if(s[i].x==s[i-].x)
{
b[s[i].y]=k;
mp[s[i].x]=k;// 与元素的相互映射
mpp[k]=s[i].x;//
}
else
{
b[s[i].y]=++k;
mp[s[i].x]=k;
mpp[k]=s[i].x;
}
}
n=k;
k=;
for(int i=;i<=t;i++)
{
if(a[i][]=='i')
{
st.push(mpp[b[++k]]);
add(b[k],,n);
}
if(a[i][]=='o')
{
int now=st.front();
st.pop();
add(mp[now],-,n);
}
if(a[i][]=='q')
{
int len=st.size();
int location=k_num((len/)+);
printf("%d\n",mpp[location]); }
}
}
return ;
}
/*
10
in 3
in 1
out
in 4
query
in 2
out
in 100
in 1
query
*/
 
 

HDU 5249 离线树状数组求第k大+离散化的更多相关文章

  1. poj 2985 The k-th Largest Group 树状数组求第K大

    The k-th Largest Group Time Limit: 2000MS   Memory Limit: 131072K Total Submissions: 8353   Accepted ...

  2. POJ2985 The k-th Largest Group[树状数组求第k大值+并查集||treap+并查集]

    The k-th Largest Group Time Limit: 2000MS   Memory Limit: 131072K Total Submissions: 8807   Accepted ...

  3. 树状数组求第K大(From CLJ)

    ; <<log2[n];p;p>>=) if(a[ret+p]<=kth) kth-=a[ret+=p]; return ret;

  4. hdu 4217 Data Structure? 树状数组求第K小

    Data Structure? Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) ...

  5. 树状数组求第k小的元素

    int find_kth(int k) { int ans = 0,cnt = 0; for (int i = 20;i >= 0;i--) //这里的20适当的取值,与MAX_VAL有关,一般 ...

  6. 区间的关系的计数 HDU 4638 离线+树状数组

    题目大意:给你n个人,每个人都有一个id,有m个询问,每次询问一个区间[l,r],问该区间内部有多少的id是连续的(单独的也算是一个) 思路:做了那么多离线+树状数组的题目,感觉这种东西就是一个模板了 ...

  7. HDU - 4777 离线树状数组

    离线树状数组搞一搞. #include<bits/stdc++.h> #define LL long long #define fi first #define se second #de ...

  8. HDU 4417 离线+树状数组

    Super Mario Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  9. UVA11525 Permutation[康托展开 树状数组求第k小值]

    UVA - 11525 Permutation 题意:输出1~n的所有排列,字典序大小第∑k1Si∗(K−i)!个 学了好多知识 1.康托展开 X=a[n]*(n-1)!+a[n-1]*(n-2)!+ ...

随机推荐

  1. JS实现对数组的去重

    JS实现对数组的去重 $scope.validateContect = function(text) { var arr = text; // 若传入的数据为string类型,用逗号分隔 if((ty ...

  2. 【Linux 运维】 Centos7.x 系统修复模式

    一.linux的运行级别: 运行级别就是来确定系统启动时到底启动那个服务. linux默认有7个运行级别: 0 关机 1 单用户模式,用于系统修复 2 不完全的命令模式,不含NFS服务 3 完全的命令 ...

  3. mac上golang编译出现clang错误

    错误现象 几周前,突然发现我的go 项目编译开始报一种以前从来没有出现过的错误: # runtime/cgo clang: warning: argument unused during compil ...

  4. NFC学习总结二

    移动支付这事情热了总归还是会回归理性,就如同之前的10几年间的几次轮回一样.字面上看,移动支付比支付大也不大可能,有相同,有扩展,有交集有不通才是. NFC这事情也是说了快十年了,真心希望它能回归到其 ...

  5. Qt Creator子目录项目-类似VS解决方案

    版权声明:若无来源注明,Techie亮博客文章均为原创. 转载请以链接形式标明本文标题和地址: 本文标题:Qt Creator子目录项目-类似VS解决方案     本文地址:http://techie ...

  6. 【Linux】- CentOS安装Mysql 5.7

    CentOS7默认数据库是mariadb,而不是mysql.CentOS7的yum源中默认是没有mysql的.所以不能使用yum install直接安装. 下载mysql的repo源 cd /usr/ ...

  7. PHPcms企业黄页中,会员注册之后提示经营模式不得少于1个字符 的解决办法

    后台--模块- 黄页模块 ---  企业库 --- 字段 ---   经营模式 ---  字符长度取值范围 1  改为  0. 

  8. [Leetcode] 2.Add Two Numbers(List To Long,模拟)

    本题题意是指将两个数倒序存储在链表中,再将两数之和同样存储在链表中输出. 我最开始的思路是将每一位相加,再考虑是否进位,但这时就需要考虑一些情况,比较麻烦. 于是我决定采取另一种在网上新学到的方法:这 ...

  9. WPF文件和文件夹的操作

    1.对文件的操作 private void button_chose_Click(object sender, RoutedEventArgs e) { var openFileDialog = ne ...

  10. BZOJ 1491 社交网络(最短路)

    对于这道题,如果我们能求出s到t的最短路径数目和s由v到t的最短路径数目,剩下的很好求了. 令dis[i][j]表示i到j的最短路径,dp[i][j]表示i到j的最短路径条数,如果dis[s][v]+ ...