[USACO15FEB]Superbull 超级牛
题意概况
题目描述
\(Bessie\)和她的朋友们正在一年一度的\(Superbull\)锦标赛中打球,而\(Farmer John\)负责让比赛尽可能激动人心。
总共有 \(N\) 支队伍 \(1 \le N \le 2000\) 参加了\(Superbull\)锦标赛。每个团队都有一个 \(1 \dots 2^{30}-1\)的团队ID。
\(Superbull\)是一场淘汰赛 - 在每场比赛之后,\(FJ\)选择淘汰其中一支球队,而被淘汰的球队再也无法参加任何比赛了。当只剩下一支球队时,比赛就结束了。
\(FJ\)注意到一个不寻常的事情:在任何游戏中,两个团队的总分是两个团队ID的按位异或(XOR)。
例如,如果第 \(12\) 队和第 \(20\) 队将参加比赛,则该游戏的得分为 \(24\) 分,因为\({01100} \quad xor \quad {10100} = {11000}\)
FJ想要设计一种比赛方案,让所有比赛的得分总和最大。请帮助\(Farmer John\)组织比赛。
输入输出格式
输入格式:第一行包括一个整数 \(N\) ,下面 \(N\) 行每行包括一个队伍的ID。
输出格式:输出一个整数,代表比赛的最大总得分。
样例解释
让 \(3\) 队与 \(9\) 队进行比赛,并让 \(9\) 队晋级。
然后他让 \(6\) 队和 \(9\) 队对决,让\(6\)队获胜。
最后,第 \(6\) 队和第 \(10\) 队比赛,\(10\)队获胜。
总得分为:\(3 \quad xor \quad 9+6 \quad xor \quad 9+6 \quad xor \quad 10=10+15+12=37。\)
样例输入
4
3
6
9
10
样例输出
37
数据范围
\(1 \le N \le 2000\)
解题报告
题意理解
给定\(n\)个人,比\(n-1\)场比赛
对于一场比赛的精彩度是两个比赛队伍的编号异或
要求所有的比赛的精彩度之和最大.
算法解析
首先,这道题目难在建图上面.
我们可以分析一下,这道题目的比赛模式.

这就是一场竞赛的四场比赛的形式.
我们发现
- 一共比了\(n-1\)场比赛,有\(n\)个人,呈现,树形结构
- 对于一场比赛,谁赢谁输并没有什么影响.
- 我们要求这些边权最大,且只能有\(n-1\)条边
- 一条边的边权,是两点编号的异或.
综上所述,我们可以使用最小生成树的变形,最大生成树来求解本题.
代码解析
#include <bits/stdc++.h>
using namespace std;
const int N=2010;
int a[N],n,m,cnt,fa[N];
struct node
{
int x,y,w;
} g[N*N];
int cmp(node a,node b)//最大排序
{
return a.w>b.w;
}
inline int find(int x)
{
return fa[x]==x?x:fa[x]=find(fa[x]);
}
inline void kruskal()
{
for(int i=1; i<=n; i++)//建立图
for(int j=1; j<=n; j++)
if (i!=j)
g[++cnt]= {i,j,a[i]^a[j]};//边权为异或
sort(g+1,g+1+cnt,cmp);//kruskal排序
int cc=0;
long long ans=0ll;//记得开long long
for(int i=1; i<=cnt; i++)
{
int x=find(g[i].x),y=find(g[i].y);
if (x==y)//已经联合
continue;
fa[x]=y;
ans+=g[i].w;
if (cc==n-1)//n-1条边凑齐了
break;
}
printf("%lld\n",ans);
}
inline void init()
{
scanf("%d",&n);
for(int i=1; i<=n; i++)
scanf("%d",&a[i]),fa[i]=i;
kruskal();
}
signed main()
{
init();
return 0;
}
[USACO15FEB]Superbull 超级牛的更多相关文章
- APT和它的超级牛力
当你在使用apt时,例如“apt -h”会提示“本APT具有超级牛” 先把牛放一放,先学习以下关于APT的知识. APT 高级打包工具(英语:Advanced Packaging Tools,缩写为A ...
- IntelliJ IDEA 15款 神级超级牛逼插件推荐(超赞,谁用谁知道)
满满的都是干货 所有插件都是在 ctrl+alt+s 里的plugins 里进行搜索安装 1.CodeGlance 代码迷你缩放图插件 2. Codota 代码提示工具,扫描你的代码后,根据你的敲击 ...
- 温故而知新 css + html 超级牛逼的居中策略
该方法甚至可以解决img内容居中的问题 套路:最外层div宽度为居中内容所占的宽度(通常是1170px),并且使其居中(margin:auto) 里层的div宽度为全屏(通常是1920px;)再mar ...
- hibernate 超级牛x的公共类
想法,能支持in查询和 =查询的 公共方法,类似下面实现 用 泛型 实现 参数 getList(String[] params,Object[] values){} for(int i=0;i< ...
- 发现XMind一个超级牛逼的功能
本来想要自己手动建立下文件夹的结构图,一不小心发现了一个大惊喜. 比如想要看一下360Downloads文件夹下的文件结构,可以先创建一个名叫360Downloads的主节点,然后把其文件夹下的文件直 ...
- 洛谷P3122 [USACO15FEB]圈住牛Fencing the Herd(计算几何+CDQ分治)
题面 传送门 题解 题目转化一下就是所有点都在直线\(Ax+By-C=0\)的同一侧,也就可以看做所有点代入\(Ax+By-C\)之后的值符号相同,我们只要维护每一个点代入直线之后的最大值和最小值,看 ...
- [USACO15FEB]Superbull (最小生成树)
题目链接 Solution 基本上就是个板子. 因为 \(n\) 很小,只有 \(2000\),所以直接暴力建图,然后跑最小生成树就好了. Code #include<bits/stdc++.h ...
- 超级牛X的免费开源小工具之tldr
github介绍:http://tldr-pages.github.io/ github源码:https://github.com/tldr-pages/tldr 什么是tldr? 新命令行世界?还是 ...
- js 模板引擎 - 超级强大
本来没想写这篇文章,但是网上误导大众的文章太多了,所以今天就抽出半小时时间谈一下我对前端模板引擎的感受吧. 前端模板引擎相信大家都再熟悉不过了,市面上非常多的号称最好.最快.最牛逼的,随便就能找到一大 ...
随机推荐
- beSTORM之网络协议Fuzz入门教程
转载自FreeBuf.COM 本文将以SNMP协议为例介绍如何使用beSTORM进行网络协议Fuzz. 实验环境 Windows 7 X64 (IP:192.168.0.123) beSTORM 3. ...
- leetcode mysql
给定一个 salary 表,如下所示,有 m = 男性 和 f = 女性 的值.交换所有的 f 和 m 值(例如,将所有 f 值更改为 m,反之亦然).要求只使用一个更新(Update)语句,并且没有 ...
- springboot datajpa 简明说明
findById返回Optional的使用 查询 public Object lookupDevice(Integer id) { return deviceJpa.findById(id).orEl ...
- 洛谷 题解 P1196 【[NOI2002]银河英雄传说】
并查集大难题. 看了题解之后才有思路,调了很久很久才AC,当然要写一篇题解来纪念一下. 先来分析一下这些指令的特点,很容易发现对于每个M指令,只可能一次移动整个队列,并且是把两个队列首尾相接合并成一个 ...
- mysql 不支持group by的解决方案
进入mysql命令行 执行如下两句语句 set global sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_ ...
- 【AtCoder】AGC006
AGC006 A - Prefix and Suffix -- #include <bits/stdc++.h> #define fi first #define se second #d ...
- ros msg和srv使用
在包文件中新建文件夹srv和msg,在这两个文件夹中新建test.msg,test.srv 修改apckage.xml 添加以下内容 <build_depend>:message_gene ...
- 剑指offer18:操作给定的二叉树,将其变换为源二叉树的镜像。
1 题目描述 操作给定的二叉树,将其变换为源二叉树的镜像. 2 输入描述: 二叉树的镜像定义:源二叉树 8 / \ 6 10 / \ / \ 5 7 9 11 镜像二叉树 8 / \ 10 6 / \ ...
- LeetCode. 矩阵中的最长递增路径
题目要求: 给定一个整数矩阵,找出最长递增路径的长度. 对于每个单元格,你可以往上,下,左,右四个方向移动. 你不能在对角线方向上移动或移动到边界外(即不允许环绕). 示例: 输入: nums = [ ...
- vc++6.0中查看函数栈的结构
栈:一种后进先出的数据结构 比如:弹夹 函数调用的约定 传参顺序 传参媒介 如何传递返回值 平衡参数(堆栈平衡):有且只有被调方(callee)和调用方(caller)一方执行 _cdell (c ...