bzoj 2151 贪心
几乎完全类似于1150的思路,直接参考那个就行了。
http://www.cnblogs.com/BLADEVIL/p/3527193.html
- /**************************************************************
- Problem:
- User: BLADEVIL
- Language: Pascal
- Result: Accepted
- Time: ms
- Memory: kb
- ****************************************************************/
- //By BLADEVIL
- type
- pointer=^rec;
- rec =record
- pred, succ :pointer;
- num, fuck :longint;
- end;
- shit =record
- shit1, shit2 :longint;
- end;
- var
- n, m :longint;
- a :array[..] of pointer;
- left, right, size :array[..] of longint;
- key, adr :array[..] of longint;
- t, tot :longint;
- ans :longint;
- procedure left_rotate(var t:longint);
- var
- k :longint;
- begin
- k:=right[t];
- right[t]:=left[k];
- left[k]:=t;
- size[k]:=size[t];
- size[t]:=size[left[t]]+size[right[t]]+;
- t:=k;
- end;
- procedure right_rotate(var t:longint);
- var
- k :longint;
- begin
- k:=left[t];
- left[t]:=right[k];
- right[k]:=t;
- size[k]:=size[t];
- size[t]:=size[left[t]]+size[right[t]]+;
- t:=k;
- end;
- procedure maintain(var t:longint;flag:boolean);
- begin
- if not flag then
- begin
- if size[left[left[t]]]>size[right[t]] then
- right_rotate(t) else
- if size[right[left[t]]]>size[right[t]] then
- begin
- left_rotate(left[t]);
- right_rotate(t);
- end else exit;
- end else
- begin
- if size[right[right[t]]]>size[left[t]] then
- left_rotate(t) else
- if size[left[right[t]]]>size[left[t]] then
- begin
- right_rotate(right[t]);
- left_rotate(t);
- end else exit;
- end;
- maintain(left[t],false);
- maintain(right[t],true);
- maintain(t,true);
- maintain(t,false);
- end;
- procedure insert(var t:longint;v,k:longint);
- begin
- if t= then
- begin
- inc(tot);
- t:=tot;
- left[t]:=;
- right[t]:=;
- size[t]:=;
- key[t]:=v;
- adr[t]:=k;
- end else
- begin
- inc(size[t]);
- if v<key[t] then insert(left[t],v,k) else
- if v>key[t] then insert(right[t],v,k) else
- if v=key[t] then
- if k>adr[t] then insert(right[t],v,k) else
- insert(left[t],v,k);
- maintain(t,v>=key[t]);
- end;
- end;
- function delete(var t:longint;v,k:longint):shit;
- var
- damn :shit;
- begin
- dec(size[t]);
- if (v=key[t]) and (k=adr[t]) or (v>key[t]) and (right[t]=) or (v<key[t]) and (left[t]=) then
- begin
- delete.shit1:=key[t];
- delete.shit2:=adr[t];
- if (left[t]=) or (right[t]=) then
- t:=left[t]+right[t] else
- begin
- damn:=delete(left[t],v+,k);
- key[t]:=damn.shit1;
- adr[t]:=damn.shit2;
- end;
- end else
- if v<key[t] then delete:=delete(left[t],v,k) else
- if v>key[t] then delete:=delete(right[t],v,k) else
- if v=key[t] then
- if k>adr[t] then delete:=delete(right[t],v,k) else
- if k<adr[t] then delete:=delete(left[t],v,k);
- end;
- function mini(var t:longint):longint;
- begin
- if right[t]= then exit(adr[t]) else exit(mini(right[t]));
- end;
- procedure init;
- var
- i :longint;
- null :pointer;
- begin
- read(n,m);
- if m>n>> then
- begin
- writeln('Error!');
- halt;
- end;
- for i:= to n do
- begin
- new(null);
- a[i]:=null;
- read(a[i]^.num);
- end;
- for i:= to n do
- begin
- if i= then a[i]^.pred:=a[n] else a[i]^.pred:=a[i-];
- if i=n then a[i]^.succ:=a[] else a[i]^.succ:=a[i+];
- end;
- for i:= to n do a[i]^.fuck:=i;
- end;
- procedure main;
- var
- i :longint;
- x :longint;
- begin
- t:=;
- for i:= to n do insert(t,a[i]^.num,i);
- for i:= to m do
- begin
- x:=mini(t);
- ans:=ans+a[x]^.num;
- delete(t,a[x]^.num,a[x]^.fuck);
- delete(t,a[x]^.pred^.num,a[x]^.pred^.fuck);
- delete(t,a[x]^.succ^.num,a[x]^.succ^.fuck);
- a[x]^.num:=a[x]^.pred^.num+a[x]^.succ^.num-a[x]^.num;
- insert(t,a[x]^.num,x);
- a[x]^.pred^.pred^.succ:=a[x];
- a[x]^.pred:=a[x]^.pred^.pred;
- a[x]^.succ^.succ^.pred:=a[x];
- a[x]^.succ:=a[x]^.succ^.succ;
- end;
- writeln(ans);
- end;
- begin
- init;
- main;
- end.
bzoj 2151 贪心的更多相关文章
- Guard Duty (medium) Codeforces - 958E2 || (bzoj 2151||洛谷P1792) 种树 || 编译优化
https://codeforces.com/contest/958/problem/E2 首先求出N个时刻的N-1个间隔长度,问题就相当于在这些间隔中选K个数,相邻两个不能同时选,要求和最小 方法1 ...
- [bzoj 2151]种树(贪心)
题目:http://www.lydsy.com/JudgeOnline/problem.php?id=2151 分析:原型是bzoj 1150(CTSC 2007) 首先DP无法下手,想到贪心.想到贪 ...
- 【BZOJ 2151】 2151: 种树 (贪心+堆+双向链表)
2151: 种树 Description A城市有一个巨大的圆形广场,为了绿化环境和净化空气,市政府决定沿圆形广场外圈种一圈树.园林部门得到指令后,初步规划出n个种树的位置,顺时针编号1到n.并且每个 ...
- bzoj 2151 种树——贪心+后悔
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2151 似乎是半年+前讲过的.(然而看到的时候却不会了) 考虑贪心,限制就是不能选两边的.如果 ...
- bzoj 2151: 种树【贪心+堆】
和数据备份差不多 设二元组(i,a[i]),开一个大根堆把二元组塞进去,以len排序,每次取出一个二元组 因为单纯的贪心是不行的,所以设计一个"反悔"操作. 记录二元组的前驱pr后 ...
- bzoj 1193 贪心
如果两点的曼哈顿距离在一定范围内时我们直接暴力搜索就可以得到答案,那么开始贪心的跳,判断两点横纵坐标的差值,差值大的方向条2,小的条1,不断做,直到曼哈顿距离较小时可以暴力求解. 备注:开始想的是确定 ...
- bzoj 2697 贪心
就贪心就行了,首先可以看成n个格子,放物品,那么 一个物品假设放3个,放在1,k,n处,那么价值和放在1,n 是一样的,所以一个物品只放两个就行了,价值大的应该尽量放 在两边,那么排序之后模拟就行了 ...
- bzoj 3037 贪心
我们可以贪心的分析,每个点的入度如果是0,那么这个点不可能 被用来更新答案,那么我们每次找入度为0的点,将他去掉,如果他连的 点没有被更新过答案,那么更新答案,去掉该点,环的时候最后处理就行了 /** ...
- BZOJ 2151 种树
贪心+priority_queue. #include<iostream> #include<cstdio> #include<cstring> #include& ...
随机推荐
- Qt Qwdget 汽车仪表知识点拆解1 速度表示
先贴上效果图,注意,没有写逻辑,所以这些都是乱动的 这里线主要说一下中间显示速度的显示制作的方式,在这里,自己专门写了一个数字的仪表 考虑的一般的汽车是没有办法把瞬时速度提升到四位数的,所以我这里就放 ...
- deepin linux 安装/启动jeakins报错:处理
ERROR: No Java executable found in current PATH: /bin:/usr/bin:/sbin:/usr/sbin 安装报错: 1.如还未安装java,则安装 ...
- Django学习笔记(一):环境安装与简单实例
Django学习笔记(一):环境安装与简单实例 通过本文章实现: Django在Windows中的环境安装 Django项目的建立并编写简单的网页,显示欢迎语与当前时间 一.环境安装 结合版本兼容性等 ...
- tensorflow nmt基本配置(tf-1.4)
随着tensorflow的不断更新,直接按照nmt的教程搭建nmt环境会报错的...因此,需要一些不太好的办法来避免更多的问题出现.tensorflow看来在ubuntu和debian中运行是没有问题 ...
- Django 运行Admin 页面时出现 UnicodeDecodeError: 'gbk' codec can't decode byte XXXX解决方法
具体报错信息 Traceback (most recent call last): File "D:\Anaconda3\lib\site-packages\django\core\hand ...
- 深度学习-CNN tensorflow 可视化
tf.summary模块的简介 在TensorFlow中,最常用的可视化方法有三种途径,分别为TensorFlow与OpenCv的混合编程.利用Matpltlib进行可视化.利用TensorFlow自 ...
- python第三天(dictionary应用)转
1.题目: python实现英文文章中出现单词频率的统计 前言: 这道题在实际应用场景中使用比较广泛,比如统计历年来四六级考试中出现的高频词汇,记得李笑来就利用他的编程技能出版过一本背单词的畅销书 ...
- [译]如何去除Git的unstaged的文件提示“old mode 100755 new mode 100644”?
原文来源:https://stackoverflow.com/questions/1257592/how-do-i-remove-files-saying-old-mode-100755-new-mo ...
- android桌面悬浮窗仿QQ手机管家加速效果
主要还是用到了WindowManager对桌面悬浮进行管理. 需要一个火箭的悬浮窗 一个发射台悬浮窗 ,判断火箭是否放到了发射台,如果放上了,则使用AsyTask 慢慢将火箭的图片往上移.结束后., ...
- springMVC js等文件找不到解决方法
<mvc:resources mapping="/javascript/**" location="/static_resources/javascript/&qu ...