链接:http://codeforces.com/contest/1043


A - Elections - [水水水水题]

题意:

我和另一个人竞争选举,共有 $n$ 个人投票,每个人手上有 $k$ 票,必须投给我或者另一个人。

现在已知每个人给另一个人投 $a_i$ 票,也就是说会给我投 $k-a_i$ 票。求最小的整数 $k$,使得我的票数严格大于另一个人。

题解:

暴力枚举 $k$。

AC代码:

#include<bits/stdc++.h>
using namespace std;
const int maxn=;
int n,a[maxn];
int main()
{
cin>>n;
int mx=,sum=;
for(int i=;i<=n;i++)
scanf("%d",&a[i]), mx=max(a[i],mx), sum+=a[i];
for(int k=mx;;k++)
{
if(sum<n*k-sum)
{
printf("%d\n",k);
break;
}
}
}

B - Lost Array - [简单数学题]

题意:

我手上有一个序列 $x_0,x_1, \cdots, x_{k-1}$。

现在又有一个长度为 $n+1$ 的序列 $a_0,a_1,a_2, \cdots, a_n$,已知这个序列是通过 $a_i = x_{(i-1) \bmod k} + a_{i-1}$ 计算得到,其中 $i \ge 0$ 且 $a_0 = 0$。

现在序列 $x_0,x_1, \cdots, x_{k-1}$ 丢失了,但给你 $a_0,a_1,a_2, \cdots, a_n$,求可能的 $k(1 \le k \le n)$。

题解:

显然从 $a_1$ 到 $a_k$ 是可以用来直接确定 $x_0,x_1, \cdots, x_{k-1}$,而后面的 $a_{k+1} \sim a_n$ 可以用来判定是否矛盾,不矛盾就是可行的 $k$。

AC代码:

#include<bits/stdc++.h>
using namespace std;
const int maxn=1e3+;
int n,a[maxn];
int x[maxn];
inline bool ok(int k)
{
for(int i=;i<=k;i++) x[i-]=a[i]-a[i-];
for(int i=k+;i<=n;i++) {
if(a[i]!=x[(i-)%k]+a[i-]) return ;
}
return ;
}
int main()
{
cin>>n;
a[]=;
for(int i=;i<=n;i++) scanf("%d",&a[i]);
vector<int> ans;
for(int k=;k<=n;k++) {
if(ok(k)) ans.push_back(k);
}
printf("%d\n",ans.size());
for(int i=;i<ans.size();i++) printf("%s%d",i>?" ":"",ans[i]);
}

C - Smallest Word - [简单模拟]

题意:

给出只包含字符 $a,b$ 的字符串 $s$,现在你从长度为 $1$ 到 $|s|$ 依次遍历所有的前缀子串,你可以选择反转这个前缀子串,或者不动。

现在要你输出 $|s|$ 个选择,使得最后的 $s$ 字典序最小。

题解:

从左到右遍历字符串,对于第 $i$ 个字符,始终保持 $1 \sim i-1$ 个字符保持 "$a,a,\cdots,a,b,b,\cdots,b$" 或者 "$b,b,\cdots,b,a,a,\cdots,a$" 这样的样式。

可以使得最后字符串为 "$a,a,\cdots,a,b,b,\cdots,b$"。

AC代码:

#include<bits/stdc++.h>
using namespace std;
string s;
int main()
{
cin>>s;
char pre=s[];
for(int i=;i<s.size();i++)
{
if(s[i]=='a')
{
if(pre=='b') printf("1 "), pre='a';
else printf("0 ");
}
if(s[i]=='b')
{
if(pre=='a') printf("1 "), pre='b';
else printf("0 ");
}
}
if(pre=='a') printf("1\n");
else printf("0\n");
}

D - Mysterious Crime - [双指针维护]

题意:

给出 $m$ 个 $1 \sim n$ 的排列,求所有公共子串的数目。

题解:

换句话说,就是在第 $1$ 个排列里找,在其他 $2 \sim m$ 个排列里出现的所有公共子串。

不难想到,可以将第 $1$ 个排列分成若干段,每段都是不能在往右延伸的最长公共子串,例如:$(1,2,3,6,4,5)$ 和 $(4,5,6,1,2,3)$,则可以把第 $1$ 个排列分成 $(1,2,3),(6),(4,5)$。

因此用两根指针分别维护这些段的左右端点,每次找到一个长为 $len$ 的段,就产生贡献 $\frac{(len)(len+1)}{2}$。

AC代码:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn=1e5+;
const int maxm=;
int n,m;
int nxt[maxm][maxn];
int main()
{
cin>>n>>m;
memset(nxt,,sizeof(nxt));
for(int j=;j<=m;j++)
{
for(int i=,now,pre=;i<=n;i++)
{
scanf("%d",&now);
nxt[j][pre]=now;
pre=now;
}
} ll ans=;
int len=;
for(int i=nxt[][],j;i;i=nxt[][i])
{
for(j=;j<=m;j++) {
if(nxt[j][i]!=nxt[][i]) break;
}
if(j>m && nxt[][i]) len++;
else ans+=(ll)len*(len+)/, len=;
}
cout<<ans<<endl;
}

E - Train Hard, Win Easy - (Done)

题意:

现在共有两道题目,有 $n$ 个人,每个人做第一题会得到 $x$ 的罚时,做第二题会得到 $y$ 的罚时。

他们要两两相互组队,组队之后队里的两个人会一人挑一题做(当然是罚时越小越好),他们在这一轮会得到他们队的总罚时分数。

又知道,有 $m$ 个组是不能组的(这两个人不想组一块儿),现在要求每个人最后会得到的分数。

题解:

直接上 $O(n^2)$ 地算是不现实的。考虑做减法,不妨先不管 $m$ 组人不想组队的情况,直接算出每个人和其他所有人组队,最后会得到多少分,再减去 $m$ 组不能组的分数即可。

考虑如何计算第 $i$ 个人,和其他所有人分别组队后得到的分数。先将所有人按 $x_i - y_i$ 排序,这样一来,对于第 $i$ 个人,

其前面的任意一个人 $j$ 都满足 $x_j - y_j \le x_i - y_i \Rightarrow x_j + y_i \le x_i + y_j$;也就是说,第 $i$ 个人和其前面的人组队,他本人必然会做 $y_i$ 这道题。

其后面的任意一个人 $k$ 都满足 $x_i - y_i \le x_k - y_k \Rightarrow x_i + y_k \le x_k + y_i$;也就是说,第 $i$ 个人和其后面的人组队,他本人必然会做 $x_i$ 这道题。

这样一来,我们只要 $O(n)$ 求出 $x_j$ 的前缀和以及 $y_k$ 的后缀和,然后即可 $O(1)$ 得到第 $i$ 个人的总分数。

最后减去那 $m$ 组人不想组队的情况即可。

AC代码:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef pair<int,int> pii;
const int maxn=3e5+;
int n,m;
struct P{
int id;
ll x,y;
P(){}
P(int _id,ll _x,ll _y){id=_id, x=_x, y=_y;}
bool operator<(const P& oth) {
return x-y < oth.x-oth.y;
}
}p[maxn];
pii hate[maxn];
ll xpre[maxn],ysuf[maxn];
ll ans[maxn];
int main()
{
cin>>n>>m;
for(int i=,x,y;i<=n;i++) scanf("%d%d",&x,&y), p[i]=P(i,x,y);
for(int i=;i<=m;i++) scanf("%d%d",&hate[i].first,&hate[i].second);
memset(ans,,sizeof(ans));
for(int i=,a,b;i<=m;i++)
{
a=hate[i].first, b=hate[i].second;
ll des=min(p[a].x+p[b].y,p[a].y+p[b].x);
ans[hate[i].first]-=des;
ans[hate[i].second]-=des;
}
sort(p+,p+n+); xpre[]=;
for(int i=;i<=n;i++) xpre[i]=xpre[i-]+p[i].x;
ysuf[n+]=;
for(int i=n;i>=;i--) ysuf[i]=ysuf[i+]+p[i].y; for(int i=;i<=n;i++) {
ans[p[i].id]+=xpre[i-]+(i-)*p[i].y+ysuf[i+]+(n-i)*p[i].x;
}
for(int i=;i<=n;i++) printf("%lld%c",ans[i],i==n?'\n':' ');
}

F - Make It One - [莫比乌斯反演] - (Undone)

题意:

给出 $n(1 \le n \le 3e5)$ 个数字 $a_1 \sim a_n(1 \le a_i \le 3e5)$,要求选取最少的若干个数字,使他们的最大公因数为 $1$。

题解:

Codeforces 1043 - A/B/C/D/E/F - (Undone)的更多相关文章

  1. Codeforces 1132 - A/B/C/D/E/F - (Undone)

    链接:http://codeforces.com/contest/1132 A - Regular Bracket Sequence - [水] 题解:首先 "()" 这个的数量多 ...

  2. Codeforces 1114 - A/B/C/D/E/F - (Undone)

    链接:http://codeforces.com/contest/1114 A - Got Any Grapes? 题意:甲乙丙三个人吃葡萄,总共有三种葡萄:绿葡萄.紫葡萄和黑葡萄,甲乙丙三个人至少要 ...

  3. Codeforces 1100 - A/B/C/D/E/F - (Undone)

    链接:https://codeforces.com/contest/1100 A - Roman and Browser - [暴力枚举] 题意:浏览器有 $n$ 个网页,编号 $1 \sim n$, ...

  4. Codeforces Educational Codeforces Round 44 (Rated for Div. 2) F. Isomorphic Strings

    Codeforces Educational Codeforces Round 44 (Rated for Div. 2) F. Isomorphic Strings 题目连接: http://cod ...

  5. Educational Codeforces Round 71 (Rated for Div. 2)-F. Remainder Problem-技巧分块

    Educational Codeforces Round 71 (Rated for Div. 2)-F. Remainder Problem-技巧分块 [Problem Description] ​ ...

  6. Codeforces 1043 F - Make It One

    F - Make It One 思路: dp + 容斥 首先, 答案不会超过7, 因为前7个质数的乘积大于3e5(最坏的情况是7个数, 每个数都缺少一个不同的因子) 所以从1到7依次考虑 dp[i][ ...

  7. Codeforces Bubble Cup 8 - Finals [Online Mirror] F. Bulbo DP

    F. Bulbo Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/575/problem/F Des ...

  8. Codeforces 1154 - A/B/C/D/E/F/G - (Undone)

    链接:https://codeforces.com/contest/1154 A - Restoring Three Numbers - [水] #include<bits/stdc++.h&g ...

  9. Educational Codeforces Round 58 (Rated for Div. 2) F dp + 优化(新坑) + 离线处理

    https://codeforces.com/contest/1101/problem/F 题意 有n个城市,m辆卡车,每辆卡车有起点\(s_i\),终点\(f_i\),每公里油耗\(c_i\),可加 ...

随机推荐

  1. GDAL多光谱与全色图像融合简单使用

    目录 简述 C++代码 效果对比 GDAL融合效果和原始多光谱波段对比 GDAL融合效果和原始全色波段对比 ARCGIS融合效果与原始全色和多光谱对比 GDAL融合效果与ArcGIS融合效果对比 简述 ...

  2. 【微信小程序项目实践总结】30分钟从陌生到熟悉 web app 、native app、hybrid app比较 30分钟ES6从陌生到熟悉 【原创】浅谈内存泄露 HTML5 五子棋 - JS/Canvas 游戏 meta 详解,html5 meta 标签日常设置 C#中回滚TransactionScope的使用方法和原理

    [微信小程序项目实践总结]30分钟从陌生到熟悉 前言 我们之前对小程序做了基本学习: 1. 微信小程序开发07-列表页面怎么做 2. 微信小程序开发06-一个业务页面的完成 3. 微信小程序开发05- ...

  3. 同一个tomcat下面放多个项目 每个项目用不同的域名访问

    vim ./conf/server.conf <Host name=" appBase="/www/test1/webapps" ##这是war包存放的位置 unp ...

  4. [HDFS Manual] CH8 HDFS Snapshots

    HDFS Snapshots HDFS Snapshots 1. 概述 1.1 Snapshottable目录 1.2 快照路径 2. 带快照的更新 3. 快照操作 3.1 管理操作 3.2 用户操作 ...

  5. WordPress <= 4.6 命令执行漏洞(PHPMailer)复现分析

    漏洞信息 WordPress 是一种使用 PHP 语言开发的博客平台,用户可以在支持 PHP 和 MySQL 数据库的服务器上架设属于自己的网站.也可以把 WordPress 当作一个内容管理系统(C ...

  6. 关于azkaban上传job压缩包报错问题的解决方案

    在azkaban上传job压缩包如果出现 installation Failed Error Chunking during uploading files to db.. 错误,可通过如下方法解决. ...

  7. CRC码计算及校验原理的最通俗诠释

    5.3.2 循环冗余校验检错方案 奇偶校验码(PCC)只能校验一位错误,本节所要介绍的循环冗余校验码(CRC)的检错能力更强,可以检出多位错误. 1. CRC校验原理      CRC校验原理看起来比 ...

  8. Zookeeper系列六:服务器角色、序列化与通信协议、数据存储、zookeeper总结

    一.服务器角色 1. Leader 1)事务请求的唯一调度者和处理者.保证事务处理的顺序性 事务请求:导致数据一致性的请求(数据发生改变).如删除一个节点.创建一个节点.设置节点数据,设置节点权限就是 ...

  9. 自己动手在win2003系统中添加虚拟网卡

    运用虚拟网卡我们可以更好地使用我们的网络,那么在win2003中该怎么操作呢?下面就为大家介绍下具体的步骤   虚拟网卡是用软件来实现虚拟的网卡,通过运用虚拟网卡我们可以更好地使用我们的网络.但是虚拟 ...

  10. 图像的下采样Subsampling 与 上采样 Upsampling

     I.目的 缩小图像(或称为下采样(subsampled)或降采样(downsampled))的主要目的: 1.使得图像符合显示区域的大小: 2.生成对应图像的缩略图. 放大图像(或称为上采样(ups ...