1650

简单题 线段树的单点更新 就是字符串神马的 有点小繁琐 开两个map 一个存城市 一个存名字

 #include <iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cstdlib>
#include<string>
#include<map>
using namespace std;
#define N 60010
#define LL long long
LL s[N<<];
LL a[N],pp[N];
map<string,int>q;
map<string,int>qq;
char pq[N][];
struct node
{
int d;
char s1[];
char s2[];
}bi[N];
struct mode
{
char ss[];
LL vv;
}ct[N];
int sd[N],g,gg,lo[N];
void up(int w)
{
s[w] = max(s[w<<],s[w<<|]);
}
void build(int l,int r,int w)
{
if(l==r)
{
s[w] = a[l];
return ;
}
int m = (l+r)>>;
build(l,m,w<<);
build(m+,r,w<<|);
up(w);
}
void update(int p,LL d,int l,int r,int w)
{
if(l==r)
{
s[w]+=d;
return ;
}
int m = (l+r)>>;
if(p<=m)
update(p,d,l,m,w<<);
else
update(p,d,m+,r,w<<|);
up(w);
}
int query(int l,int r,int w)
{
if(l==r)
{
return l;
}
int m = (l+r)>>;
if(s[w<<]>s[w<<|])
return query(l,m,w<<);
else if(s[w<<]<s[w<<|])
return query(m+,r,w<<|);
else
return ;
}
bool cmp(mode a,mode b)
{
return strcmp(a.ss,b.ss)<;
}
int main()
{
int n,k,m,i;
char s1[],s2[];
LL p;
scanf("%d",&n);
for(i = ; i <= n ; i++)
{
scanf("%s%s %lld",s1,s2,&p);
if(!q[s2])
{
g++;
q[s2] = g;
a[q[s2]]+=p;
strcpy(pq[g],s2);
}
else
a[q[s2]]+=p;
if(!qq[s1])
{
gg++;
qq[s1] = gg;
pp[gg] = p;
}
lo[qq[s1]] = q[s2];
}
scanf("%d%d",&m,&k);
for(i = ; i <= k ; i++)
{
scanf("%d%s%s",&bi[i].d,bi[i].s1,bi[i].s2);
if(!q[bi[i].s2])
{
g++;
q[bi[i].s2] = g;
strcpy(pq[g],bi[i].s2);
}
}
build(,g,);
int o = query(,g,);
int t = ;
for(i = ; i <= k ; i++)
{
int o1 = qq[bi[i].s1];
int o2 = q[bi[i].s2];
int kk = bi[i].d;
if(o)
{
sd[o]+=(kk-t);
}
t = kk;
update(lo[o1],-pp[o1],,g,);
update(o2,pp[o1],,g,);
lo[o1] = o2;
o = query(,g,);
}
if(o)
sd[o] += m-t;
o = ;
for(i = ; i <= g ; i++)
{
if(sd[i])
{
strcpy(ct[o].ss,pq[i]);
ct[o].vv = sd[i];
o++;
}
}
sort(ct,ct+o,cmp);
for(i = ; i < o ; i++)
printf("%s %lld\n",ct[i].ss,ct[i].vv);
return ;
}

1650. Billionaires(线段树)的更多相关文章

  1. bzoj3932--可持久化线段树

    题目大意: 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si秒开始,在第 ...

  2. codevs 1082 线段树练习 3(区间维护)

    codevs 1082 线段树练习 3  时间限制: 3 s  空间限制: 128000 KB  题目等级 : 大师 Master 题目描述 Description 给你N个数,有两种操作: 1:给区 ...

  3. codevs 1576 最长上升子序列的线段树优化

    题目:codevs 1576 最长严格上升子序列 链接:http://codevs.cn/problem/1576/ 优化的地方是 1到i-1 中最大的 f[j]值,并且A[j]<A[i] .根 ...

  4. codevs 1080 线段树点修改

    先来介绍一下线段树. 线段树是一个把线段,或者说一个区间储存在二叉树中.如图所示的就是一棵线段树,它维护一个区间的和. 蓝色数字的是线段树的节点在数组中的位置,它表示的区间已经在图上标出,它的值就是这 ...

  5. codevs 1082 线段树区间求和

    codevs 1082 线段树练习3 链接:http://codevs.cn/problem/1082/ sumv是维护求和的线段树,addv是标记这歌节点所在区间还需要加上的值. 我的线段树写法在运 ...

  6. PYOJ 44. 【HNSDFZ2016 #6】可持久化线段树

    #44. [HNSDFZ2016 #6]可持久化线段树 统计 描述 提交 自定义测试 题目描述 现有一序列 AA.您需要写一棵可持久化线段树,以实现如下操作: A v p x:对于版本v的序列,给 A ...

  7. CF719E(线段树+矩阵快速幂)

    题意:给你一个数列a,a[i]表示斐波那契数列的下标为a[i],求区间对应斐波那契数列数字的和,还要求能够维护对区间内所有下标加d的操作 分析:线段树 线段树的每个节点表示(f[i],f[i-1])这 ...

  8. 【BZOJ-3779】重组病毒 LinkCutTree + 线段树 + DFS序

    3779: 重组病毒 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 224  Solved: 95[Submit][Status][Discuss] ...

  9. 【BZOJ-3673&3674】可持久化并查集 可持久化线段树 + 并查集

    3673: 可持久化并查集 by zky Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 1878  Solved: 846[Submit][Status ...

随机推荐

  1. C++ 对数组sizeof 和对数组元素sizeof

    这一段程序 下面这段程序很有看点://arr1 is an array of intsint *source=arr1;size_t sz=sizeof(arr1)/sizeof(*arr1);//n ...

  2. Redis源码研究--字符串

    之前看的内容,占个位子,以后补上. ------------8月2日------------- 好久没看了,惭愧,今天抽了点时间重新看了Redis的字符串,一边写博客,一边看. Redis的字符串主要 ...

  3. Dapper full example

    Skip to content Sign up Sign in This repository Explore Features Enterprise Blog Watch Star , Fork S ...

  4. psp系统需求分析

    软件开发方向“PSP系统”软件需求规约 目录 1 引言... 4 1.1 目的... 4 1.2 文档格式... 4 1.3 预期的读者和阅读建议... 4 1.4 范围... 5 1.5 术语... ...

  5. php的异步框架

    swoole目前已被多家移动互联网.物联网.网络游戏.手机游戏企业使用,替代了C++.Java等复杂编程语言来实现网络服务器程序. 使用PHP+Swoole,开发效率可以大大提升.官方提供了基于swo ...

  6. MVC5 Bundles发布到IIS失效问题解决方案

    MVC中Bundles可以提高代码的可重用性 我每个页面都需要用到这十几个JS+CSS 当我把MVC发布到服务器以后,Bundles中的JS和CSS会失效的时候 宝宝的心里是崩溃的.... 查了很多资 ...

  7. linux ssh 安装、安全设置

    环境:ubuntu 12.04   一.简单安装设置 1. 安装ssh 服务器 $ sudo apt-get install openssh 2. 查看运行状态 $ service ssh statu ...

  8. cocos2dx游戏资源加密之XXTEA

    在手机游戏当中,游戏的资源加密保护是一件很重要的事情. 我花了两天的时间整理了自己在游戏当中的资源加密问题,实现了跨平台的资源流加密,这个都是巨人的肩膀之上的. 大概的思路是这样的,游戏资源通过XXT ...

  9. 【BZOJ 1009】 [HNOI2008]GT考试

    Description 阿申准备报名参加GT考试,准考证号为N位数X1X2....Xn(0<=Xi<=9),他不希望准考证号上出现不吉利的数字.他的不吉利数学A1A2...Am(0< ...

  10. 【BZOJ 1563】 [NOI2009]诗人小G

    Description Input Output 对于每组数据,若最小的不协调度不超过1018,则第一行一个数表示不协调度若最小的不协调度超过1018,则输出"Too hard to arr ...