题面:

题解:

T1:

毕竟是tg膜你,不会太难

就是一道简单贪心

首先,对于a<=b的所有物品,一定是贪心的按照a从小到大放入。

先假设剩下的物品可以按照某种顺序放进去,那么可以得到一个最终空间(如果最终空间<0那么一定不可行)。

之后可以看成是从结束状态往回还原,还原一个物品需要扣掉b的空间,再加上a的空间,由于b>a所以是一个和前面一样的问题,按照b从小到大排序即可。

#include <bits/stdc++.h>
#define N 100005
#define ll long long
using namespace std;
inline ll read()
{
register ll x=0,t=1;register char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')t=-1;ch=getchar();}
while('0'<=ch&&ch<='9')x=(x<<3)+(x<<1)+ch-48,ch=getchar();
return x*t;
}
inline void write(register int x)
{
if(!x)putchar('0');if(x<0)x=-x,putchar('-');
static int s[25];register int top=0;
while(x){s[top++]=x%10,x/=10;}
while(top)putchar(s[--top]+48);
}
struct node{
int cost,ret;
}a[N];
inline bool cmp1(register node a,register node b)
{
return a.cost<b.cost;
}
inline bool cmp2(register node a,register node b)
{
return a.ret>b.ret;
}
int t,n;
ll v;
inline void lxldl()
{
n=read(),v=read();
for(register int i=1;i<=n;++i)
a[i].cost=read(),a[i].ret=read();
sort(a+1,a+n+1,cmp1);
for(register int i=1;i<=n;++i)
if(a[i].cost<a[i].ret)
{
if(a[i].cost>v)
{
puts("No");
return;
}
v+=a[i].ret-a[i].cost;
a[i].ret=a[i].cost=0;
}
sort(a+1,a+n+1,cmp2);
for(register int i=1;i<=n;++i)
if(a[i].cost<=v)
v+=a[i].ret-a[i].cost;
else
{
puts("No");
return;
}
puts("Yes");
}
int main()
{
freopen("a.in","r",stdin);
freopen("a.out","w",stdout);
t=read();
while(t--)
lxldl();
return 0;
}

T2:

想着各种数据结构,结果是个膜你?

由于是循环位移,所以移动N次之后方案会循环,那么只要考虑前N次移动就可以了。如果把这个绝对值的符号分情况讨论,对于一个数,它在某几次循环位移的时候会使得答案+1,在某几次循环位移的时候会使得答案-1(从1移动到N的情况可以单独考虑),并且+1和-1的时刻分别是一段区间。那么可以维护每次移动后相对于上次的变化量,维护这个变化量的时候需要区间+1/-1,查询每个位置的和。可以使用线段树,但是是在所有操作之后进行询问,所以可以用差分。

#include<bits/stdc++.h>
#define maxn 2000010
#define ll long long
using namespace std;
ll pre[maxn];
int main()
{
freopen("b.in", "r", stdin);
freopen("b.out", "w", stdout);
ll sum = 0, res = 1e18;
int n;
scanf("%d", &n);
for (int i = 1; i <= n; i++)
{
int x;
scanf("%d", &x);
sum += abs(x - i);
if (x > i)
{
pre[1]++; pre[i]--;
pre[i] += abs(x - n) - abs(x - 1);
pre[i + 1] -= abs(x - n) - abs(x - 1);
int tmp = n - x + i;
pre[i + 1]--; pre[tmp + 1]++;
pre[tmp + 1]++; pre[n]--;
}
else
{
int tmp = i - x;
pre[1]--; pre[tmp + 1]++;
pre[tmp + 1]++; pre[i]--;
pre[i] += abs(x - n) - abs(x - 1);
pre[i + 1] -= abs(x - n) - abs(x - 1);
pre[i + 1]--; pre[n]++;
}
}
res = sum;
for (int i = 1; i <= n - 1; i++)
{
pre[i] += pre[i - 1];
sum += pre[i];
res = min(res, sum);
}
printf("%lld\n", res);
return 0;
}

T3:

写个打暴力都有70pts,想什么正解(smog

正解也很简单,就是个线段树qaq

分两种情况考虑,先考虑两个线段不相互包含的情况。枚举左端点靠左的那一条线段i,另一条线段j的要求是l[j]在l[i]到r[i]之间,并且产生的答案是(r[j]-l[i])-(r[i]-l[j]),化简一下就是(l[j]+r[j])-([i]+r[i])可以用线段树按照l[j]为关键字维护l[j]+r[j]的最大值。另一种情况就是两条线段包含,依然枚举左端点靠左的那一条线段i,发现另一条线段需要维护r[j]-l[j]的最大值,也是用一棵线段树即可。

···cpp

include <bits/stdc++.h>

define N 200005

using namespace std;

inline int read()

{

register int x=0,t=1;register char ch=getchar();

while(ch<'0'||ch>'9'){if(ch'-')t=-1;ch=getchar();}

while('0'<=ch&&ch<='9')x=(x<<3)+(x<<1)+ch-48,ch=getchar();

return x*t;

}

inline void write(register int x)

{

if(!x)putchar('0');if(x<0)x=-x,putchar('-');

static int s[25];register int top=0;

while(x){s[top++]=x%10,x/=10;}

while(top)putchar(s[--top]+48);

}

inline int Min(register int a,register int b)

{

return a<b?a:b;

}

inline int Max(register int a,register int b)

{

return a>b?a:b;

}

struct node{

int l,r;

}w[N];

inline bool cmp(register node a,register node b)

{

return a.lb.l?a.r>b.r:a.l<b.l;

}

int n,a[N<<1],m=0;

struct SegmentTree{

int minn[N<<4];

inline void init()

{

memset(minn,0x3f,sizeof(minn));

}

inline void pushup(register int x)

{

minn[x]=Min(minn[x<<1],minn[x<<1|1]);

}

inline void update(register int x,register int l,register int r,register int pos,register int v)

{

if(l==r)

{

minn[x]=Min(minn[x],v);

return;

}

int mid=l+r>>1;

if(pos<=mid)

update(x<<1,l,mid,pos,v);

else

update(x<<1|1,mid+1,r,pos,v);

pushup(x);

}

inline int query(register int x,register int l,register int r,register int L,register int R)

{

if(L<=l&&r<=R)

return minn[x];

int mid=l+r>>1;

int res=0x3f3f3f3f;

if(L<=mid)

res=Min(res,query(x<<1,l,mid,L,R));

if(R>mid)

res=Min(res,query(x<<1|1,mid+1,r,L,R));

return res;

}

}tr1,tr2;

int main()

{

freopen("c.in","r",stdin);

freopen("c.out","w",stdout);

n=read();

for(register int i=1;i<=n;++i)

{

w[i].l=read(),w[i].r=read();

a[++m]=w[i].l,a[++m]=w[i].r;

}

sort(w+1,w+n+1,cmp);

sort(a+1,a+1+m);

m=unique(a+1,a+1+m)-(a+1);

for(register int i=1;i<=n;++i)

{

w[i].l=lower_bound(a+1,a+1+m,w[i].l)-a;

w[i].r=lower_bound(a+1,a+1+m,w[i].r)-a;

}

tr1.init(),tr2.init();

int ans=0;

int x;

for(register int i=1;i<=n;++i)

{

x=tr1.query(1,1,m,w[i].r,m);

ans=Max(a[w[i].l]-a[w[i].r]-x,ans);

x=tr2.query(1,1,m,w[i].l,w[i].r);

ans=Max(a[w[i].l]+a[w[i].r]-x,ans);

tr1.update(1,1,m,w[i].r,a[w[i].l]-a[w[i].r]);

tr2.update(1,1,m,w[i].r,a[w[i].l]+a[w[i].r]);

}

write(ans);

puts("");

return 0;

}


#### 这场比赛很简单 #### 暴力分给的很足, #### 本能能ak的,最后我只有大众分100+50(BIT写挂)+70(暴力+剪枝)=220pts #### gsy他235,cyc好像245 #### 深深的感受到自己的弱小~

【题解】JSOIWC2019 Round2的更多相关文章

  1. SDOI2017 Round2 详细题解

    这套题实在是太神仙了..做了我好久...好多题都是去搜题解才会的 TAT. 剩的那道题先咕着,如果省选没有退役就来填吧. 「SDOI2017」龙与地下城 题意 丢 \(Y\) 次骰子,骰子有 \(X\ ...

  2. 【题解】JSOIWC2019 Round 5

    题面: 题解: T1: 算法1: 枚举每个灯塔的方向,并分别判断是否有解.时间复杂度O(K*4^K). 预计得分:50-70分 算法2: 不难发现,当k≥4的时候一定有解,将最靠左的两个下面的朝右上. ...

  3. 【题解】JSOIWC2019 Round4

    题面: https://files-cdn.cnblogs.com/files/yzhang-rp-inf/P13.gif https://files-cdn.cnblogs.com/files/yz ...

  4. 【题解】JSOIWC2019 Round3

    题面 题解: T1: 先对图进行染色,重新对联通快重新建图 根据四色定理,珂以得出这实际是一颗树 因为树的中心肯定是最佳的决策,所以答案就是树的直径/2(上取整) #include <bits/ ...

  5. 【题解】JSOIWC2019 Round1

    题面(T1变成5s(毒瘤出题人发现std超时了qaq)): 啥都不会qaq.但也送了不少分 题解: T1: 当T=0时直接异或前缀和,但T=1时就有点恶心 暴力能有80pts(防止大家爆零) 还珂以用 ...

  6. AHOI2013 Round2 Day2 简要题解

    第一题: 第一问可以用划分树或主席树在O(nlog2n)内做出来. 第二问可以用树状数组套主席树在O(nlog2n)内做出来. 我的代码太挫了,空间刚刚卡过...(在bzoj上) 第二题: 分治,将询 ...

  7. AHOI2013 Round2 Day1 简要题解

    第一题,好吧这是个dp.(搜素也能在BZOJ上卡过). 第二题,BFS搜索碰到的立方体面数,智硬没有想到... 第三题,其实一看就有思路,但关键是求x坐标不交的矩形对数+y坐标不交的矩形对数 - x, ...

  8. 【ContestHunter】【弱省胡策】【Round2】

    官方题解:http://wyfcyx.is-programmer.com/posts/95490.html A 目前只会30分的暴力……DP好像很神的样子0.0(听说可以多次随机强行算? //Roun ...

  9. JSOIWC2019游记

    世除我WC...都去广二了qaq,就我还在nj ycs至少也去了pkuwc啊 这个JSOIWC2019的内容看起来很水,进入条件简单,但窝啥都不会,肯定垫底 内容清单: 1.26 上午听机房dalao ...

随机推荐

  1. js - 伪数组转化为数组的几种方法整理(更新中...)

    伪数组:无法调用数组的方法,但是有length属性,又可以索引获取内部项的数据结构. 比如:arguments.getElementsByTagName等一系列dom获取的NodeList对象,他们 ...

  2. roadhog 介绍

    官方网站:https://www.npmjs.com/package/roadhog; 项目搭建demo: https://github.com/ght5935/antd-dva-less-webpa ...

  3. python 中的 list dict 与 set 的关系

    转自: http://www.cnblogs.com/soaringEveryday/p/5044007.html list arraylist 实现(数组) List 通过内置的 append()方 ...

  4. orace函数

    处理字符的函数 lower(char);//把字符串转换成小写格式 upper(char);//把字符转换成大写 length(char);//返回字符串的长度 substr(char,m,n);// ...

  5. Spring-Boot构建多模块项目

    Spring-Boot构建多模块项目 功能模块单独项目开发,可以将一个庞大的项目分解成多个小项目,便于细分开发 Maven多模块项目不能独立存在,必须有一个介质来包含. 1.创建一个Maven 项目, ...

  6. 剑指offer——python【第28题】数组 中出现次数超过一半的数字

    题目描述 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字.例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}.由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2. ...

  7. 【zc】 php计算两个日期相隔多少年,多少月,多少日的函数

    /* *function:计算两个日期相隔多少年,多少月,多少天 *数据接受格式: '2014-12-03','2000-12-01'; *param string $date1[格式如:2011-1 ...

  8. leetcode-Evaluate the value of an arithmetic expression in Reverse Polish Notation

    leetcode 逆波兰式求解 Evaluate the value of an arithmetic expression in Reverse Polish Notation. Valid ope ...

  9. 解决键盘输入被JDB占用的问题

    解决键盘输入被JDB占用的问题 本周的任务"迭代和JDB"在使用JDB调试时需要键盘输入数据,但我在正确的位置输入数据后发现JDB提示如图所示的错误. 上网查找后得知该错误的产生是 ...

  10. Gym 102056I - Misunderstood … Missing - [DP][The 2018 ICPC Asia-East Continent Final Problem I]

    题目链接:https://codeforces.com/gym/102056/problem/I Warm sunshine, cool wind and a fine day, while the ...