20160723数据结构节alexandrali
大坑最后再填。
20160803:心情好回来填啦(5/7)
做的题目是:
poj2970

我们先每个人都不给钱qwq
然后我们发现有一位的工作时间超过了d
那么我们就从以前安排过工作的人里,a最大的,给他加上一定量的x,使得后面的这个超出di的工作者可以在di前完成任务,或者他的工作时间已经为0,则继续找剩下的当中a最大的
这个过程用堆维护,时间复杂度O(nlogn)
struct data{
int a,b,d;
bool operator <(const data&b)const {
return a<b.a;
}
};
bool cmp(const data&a,const data&b){
return a.d<b.d;
}
int n;data a[100005];
priority_queue<data>q;
int main(){
n=gi;
FOR1(i,n){
a[i].a=gi;a[i].b=gi;a[i].d=gi;
}
sort(a+1,a+n+1,cmp);
long long sum=0;
double ans=0;
FOR1(i,n){
sum+=a[i].b;
q.push(a[i]);
while(!q.empty()&&sum>a[i].d){
data c=q.top();q.pop();
if(sum-c.b>a[i].d){
ans=ans+(double)c.b/c.a;
sum=sum-c.b;
}
else{
ans=ans+(double)(sum-a[i].d)/c.a;
c.b=c.b-sum+a[i].d;
sum=a[i].d;
q.push(c);
}
}
}
printf("%.2f\n",ans);
return 0;
}
poj2796

首先由于元素非负,sum[l,r]的值随区间长度增长,单调不降
那么我们求出对于每个元素,以它为最小值的区间最左到哪里,最右到哪里即可
我们用单调栈实现,复杂度就是O(n)
int n,a[100005];
ll qzh[100005];
int pr[100005],nx[100005],ds[100005],top;
int main(){
RI(n);
FOR1(i,n){
a[i]=gi;
qzh[i]=qzh[i-1]+a[i];
}
FOR1(i,n){
while(top&&a[ds[top]]>=a[i])--top;
pr[i]=top?ds[top]:0;
ds[++top]=i;
}
top=0;
FORD(i,n,1){
while(top&&a[ds[top]]>=a[i])--top;
nx[i]=top?ds[top]:n+1;
ds[++top]=i;
}
ll ans=0;int l=1,r=1;
FOR1(i,n){
ll t=(qzh[nx[i]-1]-qzh[pr[i]])*(ll)(a[i]);
if(t>ans){
r=nx[i]-1;l=pr[i]+1;
ans=t;
}
}
cout<<ans<<endl;cout<<l<<' '<<r;
return 0;
}
ural 1003

考虑前缀和的奇偶性
区间和是奇数的,说明头尾的前缀和奇偶性不同区间和是偶数的,说明头尾的前缀和奇偶性相同
直接使用并查集维护这个关系,回答询问
int l,n,block;
int a[5001],b[5001],f[100006];
char s[5001][6];
int find(int x){
return f[x]==x?x:f[x]=find(f[x]);
}
void uni(int a,int b){
int p,q;
p=find(a);
q=find(b);
if(q!=p)
f[q]=p;
}
int main(){
block=50003;
while (scanf("%d",&l),l!=-1){
scanf("%d",&n);
FOR1(i,n)
a[i]=gi,b[i]=gi,scanf("%s",s[i]);
FOR1(i,block*2)f[i]=i;
f[0]=1;
int i=1;
for(;i<=n;i++){
int x=(a[i]-1)%block,y=b[i]%block;
if(s[i][0]=='e'){
if(find(x)==find(y+block))break;
uni(x,y);
uni(x+block,y+block);
}else{
if(find(x+block)==find(y+block))break;
uni(x,y+block);
uni(x+block,y);
}
}
printf("%d\n",i-1);
}
}
sgu 180
逆序对裸题,有很多做法,过于简单不贴代码了
ural 1028
【题意】给定多个二维坐标,求每个点左下角的点数
树状数组
poj版需要特判重点
int c[32005];
int lowbit(int x){
return x &(-x);
}
int sum(int i){
int s=0;
while(i>0){
s=s+c[i];
i=i-lowbit(i);
}
return s;
}
void update(int i,int value){
while(i<=32005){
c[i]=c[i]+value;
i=i+lowbit(i);
}
}
int level[32005];
int main(){
int Case;
scanf("%d",&Case);
int x,y;
for(int i=0;i<Case;i++){
scanf("%d%d",&x,&y);
int tmp=sum(++x);
level[tmp]++;
update(x,1);
}
for(int i=0;i<Case;i++)
printf("%d\n",level[i]);
return 0;
}
poj2944 、sgu 336
不会做
强烈推荐在vjudge做
20160723数据结构节alexandrali的更多相关文章
- [转]RegExp 构造函数创建了一个正则表达式对象,用于将文本与一个模式匹配
本文转自:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/RegExp RegExp ...
- 第五节 Go数据结构之队列
一.什么是队列 数据结构里的队列就是模仿现实中的排队.如上图中狗狗排队上厕所,新来的狗狗排到队伍最后,最前面的狗狗撒完尿走开,后面的跟上.可以看出队列有两个特点: (1) 新来的都排在队尾: (2) ...
- ASP.NET MVC深入浅出系列(持续更新) ORM系列之Entity FrameWork详解(持续更新) 第十六节:语法总结(3)(C#6.0和C#7.0新语法) 第三节:深度剖析各类数据结构(Array、List、Queue、Stack)及线程安全问题和yeild关键字 各种通讯连接方式 设计模式篇 第十二节: 总结Quartz.Net几种部署模式(IIS、Exe、服务部署【借
ASP.NET MVC深入浅出系列(持续更新) 一. ASP.NET体系 从事.Net开发以来,最先接触的Web开发框架是Asp.Net WebForm,该框架高度封装,为了隐藏Http的无状态模 ...
- 第六节 Go数据结构之集合
一.什么是集合 集合就是不同对象的无序聚集.那么链表和集合有什么关系呢?我们来变个魔术.如下图是各种颜色组成的链表: 下面我们一步步把链表变成集合. 第一步砍去链接 第二步去掉重复 第三步放到一个框里 ...
- 第四节 Go数据结构之栈
一.什么是栈 这是杭州地铁1号线线路图.大卫哥考考大家,地铁列车如何调头? 我也不卖关子了,列车通常是用"人字轨道"来变换车道. 列车先从A轨道开进"人字轨道" ...
- [数据结构]——二叉树(Binary Tree)、二叉搜索树(Binary Search Tree)及其衍生算法
二叉树(Binary Tree)是最简单的树形数据结构,然而却十分精妙.其衍生出各种算法,以致于占据了数据结构的半壁江山.STL中大名顶顶的关联容器--集合(set).映射(map)便是使用二叉树实现 ...
- 基本数据结构(2)——算法导论(12)
1. 引言 这一篇博文主要介绍链表(linked list),指针和对象的实现,以及有根树的表示. 2. 链表(linked list) (1) 链表介绍 我们在上一篇中提过,栈与队 ...
- 学习javascript数据结构(三)——集合
前言 总括: 本文讲解了数据结构中的[集合]概念,并使用javascript实现了集合. 原文博客地址:学习javascript数据结构(三)--集合 知乎专栏&&简书专题:前端进击者 ...
- 学习javascript数据结构(二)——链表
前言 人生总是直向前行走,从不留下什么. 原文地址:学习javascript数据结构(二)--链表 博主博客地址:Damonare的个人博客 正文 链表简介 上一篇博客-学习javascript数据结 ...
随机推荐
- SQL Server 事务处理 回滚事务
--创建表: GO CREATE TABLE [dbo].[tb1]( [Id] [int] NOT NULL, [c1] [nvarchar](50) NULL, [c2] [datetime] N ...
- Oracle在所有内容前追加一些内容的方法
参照下面的sql语句. SQL> SELECT * FROM UserInfo; NAME CHINESE -------------------- ...
- 利用 NUget包 EPPlus 实现数据导出到Excel(适用于MVC)
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAvoAAABpCAIAAADEEBBGAAAJdElEQVR4nO3cy2ob5wLA8TxKnqTrrr
- JavaScript、jQuery、HTML5、Node.js实例大全-读书笔记4
5.2.2 让瀑布流动起来 打好基建之后,就需要写JavaScript代码.首先如果数据不够显示一屏幕的情况,就用新数据来补足它,在补充的时候是根据4列中最矮的那一个为优先补充,因为高矮尺寸一般只有在 ...
- struts2<s:property />标签
struts2的<property />标签是输出标签 其value属性是指定输出的内容,如果value属性没有写出来,则默认输出对象栈栈顶的元素. 例如,我们在对象栈中添加一个Perso ...
- Engine许可初始化 - gis开发初步
当需要对SDE中的要素类和要素数据集(矢量和栅格)进行编辑时,例如在调用IFeatureDataset的CreateFeatureClass方法时,报错提示: The application is n ...
- atoi 实现
int atoi(const char *nptr); 把字符串转换成整型数.ASCII to integer 的缩写. 头文件: #include <stdlib.h> 参数nptr字符 ...
- oc - runtime运行机制
Objective-C语言是一门动态语言,它将很多静态语言在编译和链接时做的事放到了运行时来处理.同时OC也是一门简单的语言,很大一部分是C的内容,只是在语言层面上加了关键字和语法,真正让OC强大 ...
- <邮件服务postfix+mysql>MAIL第二篇
环境:本服务是建立在第一篇的基础之上的,最好搭建好第一篇 玩此服务的前提是你的系统装好了msql和postfix服务. Postfix+mysql主要是把邮件服务的发与mysql结合使用.当然mysq ...
- 《postfix邮件服务下mailq、postmap、postqueue 、 postsuper等用法》
1.Mailq 功能说明:显示待寄邮件的清单. 语 法:mailq [-q] 补充说明:mailq可列出待寄邮件的清单,包括邮件ID,邮件大小,邮件保存时间,寄信人,收信人,以及邮件无法寄出的原因,提 ...