【赛时总结】 ◇赛时·I◇ AtCoder ARC-098
◆赛时I◆ ARC-098
■试题&解析■
◆本场最水◆ C-Attention
长点儿信心吧……
【解析】
既然只存在左右(东西)两个朝向,那么领导右侧的人应朝左,相反左侧的人朝右。则要找到一个人作为领导使上述人的数量最多。
我们可以用 tot[0]、tot[1] 分别储存最初朝东、西的人的个数。然后从第一个人开始枚举,统计当前人左侧的分别朝向东、西的人的个数,从而算出当前人左侧朝右、右侧朝左的人的个数,记为F。领导人即是算出F最大的人。
注意统计时要排开当前人的数量(领导人不算在内,不需要改变朝向)。【源代码】
/*Lucky_Glass*/
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define MAXN int(3*1e5)
int len,tot[2],res[2],ans;
char s[MAXN+5];
int main()
{
scanf("%d%s",&len,s);
for(int i=0;i<len;i++)
tot[s[i]=='E']++;
ans=1e9;
for(int i=0;i<len;i++)
{
int F=0;
F+=res[0];
F+=tot[1]-res[1]-int(s[i]=='E');
res[s[i]=='E']++;
ans=min(ans,F);
}
printf("%d\n",ans);
return 0;
}
◆脑壳开窍◆ D-Xor Sum 2
没办法,作者就是脑壳不开窍啊 QwQ
- 【AtCoder ARC-098 D】
- 【解析】
其实这道题我没有看出来我哪里TLE了,和正解的算法一样——滑动窗口,可能是写的丑吧。
对于异或有一个技巧——如果 A^BA+B ,则 A&B0 即A、B的二进制的各个数位都不相同。现在问题就变成寻找一个区间 [l,r] 使得 Ai&Aj=0
(i≠j 且 l≤i,j≤r)。
定义区间左右端点l、r,并初始化l=1,r=0。保证 r < n(即 r+1≤n 且 l≤r )。定义当前区间的所有数异或所得到的值为F,初始化为0。
若 A[r+1]&F0 即当前区间向右扩充1后,仍然满足所给条件,则更新F、r,向右扩充,并同时更新ans,增加的答案个数为扩充后区间的长度。用while循环执行此操作。
第一次while循环结束后,则要么枚举完了,要么 F&A[r+1]!=0 ,此时无论如何向右扩充都无法满足题目所给条件,所以只能删除左侧,直到再次满足 F&A[r+1]0 (当区间为空时,也满足 F&A[r+1]==0 )。
注意:ans用 long long 储存。
- 【源代码】
/*Lucky_Glass*/
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int MAXN=2*1e5;
int n,A[MAXN+5];
int main()
{
scanf("%d",&n);
for(int i=1;i<=n;i++)
scanf("%d",&A[i]);
int l=1,r=0,F=0;
long long ans=0;
while(r<n)
{
while(r<n && !(F&A[r+1]))
{
r++;ans+=r-l+1;
F^=A[r];
}
while(l<=r && (F&A[r+1]))
F^=A[l++];
}
printf("%lld\n",ans);
return 0;
}
◆想不到吧◆ E - Range Minimum Queries
这个是真的想不到 (u_u)
- 【AtCoder ARC-098 E】
- 【解析】
对答案有影响的变量主要是最大值和最小值,那么就可以先通过枚举限制其中一个变量(这里我用最小值)。
限制最小值,也就是说枚举Ai,在选取区间时,区间中最小的元素不能小于Ai。这样我们就可以将 A 分成多个段——每个段中的元素都大于等于Ai。这样就限制了区间中取到的最小值,但是此时的最小值不一定是Ai(比如枚举到的Ai=2,则当k=2时数据“1 2 1”就取不到2)。最小值确定后,要使最大值减最小值最小,则需要让最大值尽量小,即抽取到的数要尽量小。
那么我们可以提取出各个满足长度大于等于k的段。这些段可以作为选取区间的段,且设段的长度为len,我们可以在这个段里取 len-k+1 次区间(每一次选取都会使段的长度减少1,直到区间长度小于k)。可见如果取 len-k+1 次区间,则一定可以取出这个段里前 len-k+1 小的数。
为了使取出的数尽量小,我们需要尽量使每个段中取出的数都尽量小,也就是段中前 len-k+1 小的数。我们可以将这些数存入另外一个数组(pri),方便最后找到最小的最大值。由于我们要进行Q次抽取,最小的最大值一定是 pri 中第 Q 小的数,而最小值就是 pri 中最小的数。 - 【源代码】
/*Lucky_Glass*/
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<vector>
using namespace std;
const int MAXN=2000;
const int INF=(int)1e9+5;
int n,k,q,A[MAXN+5],ans=INF;
void SOLVE(int x)
{
vector<int> pri;
int i=0;
while(i<n)
{
vector<int> que;
while(A[i]<x && i<n) i++;
while(A[i]>=x && i<n) que.push_back(A[i++]);
if(que.size()>=k)
{
sort(que.begin(),que.end());
for(int j=0;j<(int)que.size()-k+1;j++)
pri.push_back(que[j]);
}
}
sort(pri.begin(),pri.end());
if((int)pri.size()>=q)
ans=min(ans,pri[q-1]-pri[0]);
}
int main()
{
scanf("%d%d%d",&n,&k,&q);
for(int i=0;i<n;i++)
scanf("%d",&A[i]);
for(int i=0;i<n;i++)
SOLVE(A[i]);
printf("%d\n",ans);
return 0;
}
(F题真的不会做了,请各位神牛多多指点)
The End
Thanks for reading!
-Lucky_Glass
【赛时总结】 ◇赛时·I◇ AtCoder ARC-098的更多相关文章
- 【AtCoder】 ARC 098
link C-Attention 题意:一个字符队列,每个位置是\(W\)或\(E\),计算最小的修改数量,使得存在一个位置,它之前的都是\(E\),之后的都是\(F\) #include<bi ...
- 【题解】Atcoder ARC#90 F-Number of Digits
Atcoder刷不动的每日一题... 首先注意到一个事实:随着 \(l, r\) 的增大,\(f(r) - f(l)\) 会越来越小.考虑暴力处理出小数据的情况,我们可以发现对于左端点 \(f(l) ...
- AtCoder ARC 076E - Connected?
传送门:http://arc076.contest.atcoder.jp/tasks/arc076_c 平面上有一个R×C的网格,格点上可能写有数字1~N,每个数字出现两次.现在用一条曲线将一对相同的 ...
- AtCoder ARC 076D - Built?
传送门:http://arc076.contest.atcoder.jp/tasks/arc076_b 本题是一个图论问题——Manhattan距离最小生成树(MST). 在一个平面网格上有n个格点, ...
- AtCoder ARC 082E - ConvexScore
传送门:http://arc082.contest.atcoder.jp/tasks/arc082_c 本题是一个平面几何问题. 在平面直角坐标系中有一个n元点集U={Ai(xi,yi)|1≤i≤n} ...
- Atcoder ARC 082C/D
C - Together 传送门:http://arc082.contest.atcoder.jp/tasks/arc082_a 本题是一个数学问题. 有一个长度为n的自然数列a[1..n],对于每一 ...
- 【题解】 AtCoder ARC 076 F - Exhausted? (霍尔定理+线段树)
题面 题目大意: 给你\(m\)张椅子,排成一行,告诉你\(n\)个人,每个人可以坐的座位为\([1,l]\bigcup[r,m]\),为了让所有人坐下,问至少还要加多少张椅子. Solution: ...
- 【题解】Atcoder ARC#96 F-Sweet Alchemy
首先,我们发现每一个节点所选择的次数不好直接算,因为要求一个节点被选择的次数大于等于父亲被选择的次数,且又要小于等于父亲被选择的次数 \(+D\).既然如此,考虑一棵差分的树,规定每一个节点被选择的次 ...
- AtCoder ARC 090 E / AtCoder 3883: Avoiding Collision
题目传送门:ARC090E. 题意简述: 给定一张有 \(N\) 个点 \(M\) 条边的无向图.每条边有相应的边权,边权是正整数. 小 A 要从结点 \(S\) 走到结点 \(T\) ,而小 B 则 ...
- 【题解】Atcoder ARC#67 F-Yakiniku Restaurants
觉得我的解法好简单,好优美啊QAQ 首先想想暴力怎么办.暴力的话,我们就枚举左右端点,然后显然每张购物券都取最大的值.这样的复杂度是 \(O(n ^{2} m)\) 的.但是这样明显能够感觉到我们重复 ...
随机推荐
- spring DelegatingFilterProxy管理过滤器
安全过滤器链 Spring Security的web架构是完全基于标准的servlet过滤器的.它没有在内部使用servlet或任何其他基于servlet的框架(比如spring mvc),所以它没有 ...
- 实现多ComboBox复杂查询 使用ComboBoxDisplay Value属性
首先创建一个类 class ComboBoxItem { public string Text { get; set; } public object Value { get; set; } //这个 ...
- td标签里内容不换行
在一些页面开发中,除自己操作外,引起换行的情况一般有: Ex一.td标签里内容长度过长引起换行: Ex二.div标签(或其他标记)里内容有文本和图片引起换行: 解决方法: 针对例子一用<nobr ...
- HttpClient4.3.3 禁止自动重定向
HttpClient4.3中默认允许自动重定向,导致程序中不能跟踪跳转情况,其实只需要在RequestConfig中setRedirectsEnabled(false)即可(默认是true): pri ...
- 粗看ES6之JSON
标签: es6 ES6新增JSON特性不是特别多,只是针对JSON某些情况下的写法上有一些优化: 当key值和value值对应变量名相同时 json对像中的方法书写 示例代码如下: <!DOCT ...
- Objective-C #define 用法解析 (转)
原文地址: http://blog.csdn.net/kindazrael/article/details/8108868 Objective-C : #define 用法解析 在 C 语言中,预处理 ...
- SublimeText插件autoprefixer : css 添加前续
/* 使用前 */ body { background: linear-gradient(to bottom, #DADADA, #000); } p a { -webkit-border-radiu ...
- Android 编码风格规范,很赞哦
1. 前言 这份文档参考了 Google Java 编程风格规范和 Google 官方 Android 编码风格规范.该文档仅供参考,只要形成一个统一的风格,见量知其意就可. 1.1 术语说明 在本文 ...
- Python3爬虫04(其他例子,如处理获取网页的内容)
#!/usr/bin/env python# -*- coding:utf-8 -*- import osimport reimport requestsfrom bs4 import Navigab ...
- React 环境搭建及页面调试方法
React 环境搭建及页面调试方法 |作者:RexFang |出处:http://www.cnblogs.com/rexfang/ |关于作者:Java 程序员一枚 |版权:本文版权归作者和博客园共有 ...