BestCoder Round #86
A题 Price List
巨水..........水的不敢相信。
#include <cstdio>
typedef long long LL;
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
int n,m,x;
scanf("%d%d",&n,&m);
LL sum = ;
; i < n; i++)
{
int x;
scanf("%d",&x);
sum = sum + (LL)x;
}
; i < n; i++)
{
LL x;
scanf("%lld",&x);
if(x > sum)
printf(");
else
printf(");
}
printf("\n");
}
;
}
这道题可以用线段树做,查询最大值,每次删掉一个点,等于单点更新一到两个点。之后复原一下即可。
#include <cstdio>
#include <cmath>
#include <cstring>
#include <algorithm>
using namespace std;
typedef long long LL;
#define mem0(x) memset(x,0,sizeof(x))
#define lson l,m,rt << 1
#define rson m+1,r,rt << 1 | 1
+ ];
LL MAX[ << ];
int t;
] , MAX[rt << | ]);}
void build(int l,int r,int rt)
{
] - a[l]); return ;}
;
build(lson);
build(rson);
pushup(rt);
}
void update(int p,int add,int l,int r,int rt)
{
if(l == r) {t = MAX[rt]; MAX[rt] = add; return ;}
;
if(p <= m)
update(p,add,lson);
else
update(p,add,rson);
pushup(rt);
}
LL query_max(int ll,int rr,int l,int r,int rt)
{
if(ll <= l && rr >= r) return MAX[rt];
LL ans = ;
;
if(ll <= m)
ans = max(ans,query_max(ll,rr,lson));
if(rr > m)
ans = max(ans,query_max(ll,rr,rson));
return ans;
}
int main()
{
int T,n;
scanf("%d",&T);
while(T--)
{
mem0(a);
mem0(MAX);
scanf("%d",&n);
; i <= n; i++)
{
scanf("%d",&a[i]);
}
build(,n-,);
LL ans = ;
; i <= n; i++)
{
int t1,t2;
&& i != n)
{
update(i,abs(a[i+]-a[i-]),,n-,),t1 = t;
update(i-,abs(a[i+]-a[i-]),,n-,),t2 = t;
}
else
{
if(i != n)
update(i,,,n-,),t1 = t;
)
update(i-,,,n-,),t2 = t;
}
ans = ans + query_max(,n-,,n-,);
&& i != n)
{
update(i,t1,,n-,);
update(i-,t2,,n-,);
}
else
{
if(i != n)
update(i,t1,,n-,);
)
update(i-,t2,,n-,);
}
}
printf("%I64d\n",ans);
}
;
}
但是这道题的正解是O(n)的算法。不是线段树。
真的感觉 被 虐智商。人家五分钟搞定这道题= =。
#include <cstdio>
#include <cmath>
#include <algorithm>
using namespace std;
typedef long long LL;
+ ;
int a[maxn], r_max[maxn], l_max[maxn];
int main()
{
int T,n;
LL ans;
scanf("%d",&T);
while(T--)
{
scanf("%d",&n);
; i <= n; i++)
{
scanf("%d",&a[i]);
}
l_max[] = ;
; i <= n; i++)
{//r_max 从左边开始到i的最大值
l_max[i] = max(l_max[i-], abs(a[i] - a[i-]));
}
r_max[n] = ;
; i >= ; i--)
{//l_max 从右边开始到i的最大值
r_max[i] = max(r_max[i+], abs(a[i+] - a[i]));
}
ans = (LL) l_max[n-] + (LL) r_max[];
; i < n; i++)
{
ans = ans + (LL) max(l_max[i-], max(r_max[i+], abs(a[i-] - a[i+]) ) );
}
printf("%I64d\n",ans);
}
;
}
多少个区间里的第k大的数不小于 m。其实就是说如果这个区间里面能找到,k个大于等于m的数,那么这个区间肯定就满足条件,后面的就不需要管了。
尺取法!!!!
#include <cstdio>
#include <algorithm>
using namespace std;
typedef long long LL;
+ ];
bool cmp(int a,int b)
{
return a>b;
}
int main()
{
int T,n,m,k;
scanf("%d",&T);
; i < T; i++)
{
scanf("%d%d%d",&n,&m,&k);
; i <= n; i++)
scanf("%d",&a[i]);
;
LL ans = ;
;
; i <= n; i++)
{
while(cnt < k && r < n)
{
r++;
cnt += (a[r] >= m);
}
if(cnt < k) break;
ans = ans + (LL) n - r + ;
cnt -= (a[i] >= m);
}
printf("%I64d\n",ans);
}
;
}
D题
BestCoder Round #86的更多相关文章
- [HDU5807] [BestCoder Round #86 1004] Keep In Touch (DP)
[HDU5807] [BestCoder Round #86 1004] Keep In Touch (DP) 题面 有三个人从一张N个点无重边的有向无环图上的三个点出发,每单位时间,他们分别选择当前 ...
- BestCoder Round #86 解题报告
A.Price List Sol 求和查询 Code #include<cstdio> #include<algorithm> #include<iostream> ...
- HDU 5805 NanoApe Loves Sequence (思维题) BestCoder Round #86 1002
题目:传送门. 题意:题目说的是求期望,其实翻译过来意思就是:一个长度为 n 的数列(n>=3),按顺序删除其中每一个数,每次删除都是建立在最原始数列的基础上进行的,算出每次操作后得到的新数列的 ...
- BestCoder Round #86 部分题解
Price List 题意: 有n件商品,每天只能买一件,并且会记录账本,问有多少次一定记多了? 题解: 就是求和,最后如果大于和就输出1,否则0. 代码: #include <bits/std ...
- HDU5808Price List Strike Back (BestCoder Round #86 E) cdq分治+背包
严格按题解写,看能不能形成sum,只需要分割当前sum怎么由两边组成就好 #include <cstdio> #include <cstring> #include <c ...
- HDU5807 Keep In Touch (BestCoder Round #86 D ) 分布式dp
#include <cstdio> #include <cstring> #include <cmath> #include <vector> #inc ...
- HDU5806 NanoApe Loves Sequence Ⅱ (BestCoder Round #86 C)二分
分析:大于等于m的变成1,否则变成0,预处理前缀和,枚举起点,找到第一个点前缀和大于m即可 找第一个点可以二分可以尺取 #include <cstdio> #include <cst ...
- HDU5805 NanoApe Loves Sequence (BestCoder Round #86 B)前后缀预处理
分析:维护空隙的差,然后预处理前缀最大,后缀最大,扫一遍 #include <cstdio> #include <cstring> #include <cmath> ...
- HDU5804 Price List (BestCoder Round #86 A)水题
分析:大于总和输出1 #include <cstdio> #include <cstring> #include <algorithm> using namespa ...
随机推荐
- 【网络基础编程】第三节 C/S
学习地址: C语言中文网 - 实现迭代服务端和客户端 GNU - Closing a Socket 前面介绍的程序,不管Service 端还是 Client端,都有一个问题,就是处理完一个 accep ...
- JQuery datepicker 日期控件设置
datepicker控件可通过参数设置进行语言切换,以下可实现,系统所有日期控件默认为中文,在特定页面或者特定条件下可切换成英语!~ HTML: <!DOCTYPE html> <h ...
- DD_belatedPNG.js解决透明PNG图片背景灰色问题
<!--[]> <script type="text/javascript" src="http://www.phpddt.com/usr/themes ...
- js自适应屏幕高度
//自适应屏幕高度 $(window).resize(function() { hightChange(); }); function hightChange(){ ; $();// iframe i ...
- OC初步 (一)
OC完全兼容C, 代码后缀名一般习惯用 *.m 或 *.mm,按惯例从 "Hello,World!" 开始,我们编写一个 test.mm 文件如下: #import <Fou ...
- 大熊君学习html5系列之------WebStorage(客户端轻量级存储方案)
一,开篇分析 Hi,大家好!大熊君又和大家见面了,(*^__^*) 嘻嘻……,这系列文章主要是学习Html5相关的知识点,以学习API知识点为入口,由浅入深的引入实例, 让大家一步一步的体会" ...
- 试图加载格式不正确的程序。 (异常来自HRESULT:0x8007000B)
异常来自HRESULT:0x8007000B 缘由:在64位操作系统下IIS发布32位的项目,报“项目依赖的dll无法读取,试图加载格式不正确的程序”错误. 原因:程序集之间的通讯要么全是64位环 ...
- CSS控制表格(table)样式
CSS控制表格样式 /* 合并边框重叠部分 */ table{border-collapse:collapse;} /* 单元格边框 */ td{border:1px solid #A7AEB1;}
- Daily Scrum Meeting ——TenthDay
一.Daily Scrum Meeting照片 二.Burndown Chart 新增了几个issues 三.项目进展 1.完成了登录界面与管理员和发布者界面的整合. 2.活动发布者界面的完成 四.问 ...
- [BZOJ4408][Fjoi 2016]神秘数
[BZOJ4408][Fjoi 2016]神秘数 试题描述 一个可重复数字集合S的神秘数定义为最小的不能被S的子集的和表示的正整数.例如S={1,1,1,4,13},1 = 12 = 1+13 = 1 ...