Highest Tower 18中南多校第一场H题
一、题意
给出N个方块,要求给出一个方案,使得
1、 所有方块都被使用到(题目数据保证这点)
2、所有方块垒成一个塔,且上面的方块宽度小于下面的方块
3、每个方块只能用一次,可以横着或者竖着。
n范围50w
二、题解
首先考虑表示一个正方形的方法:长度和宽度组成的无向图。
因为必然要把所有方块都堆好,所以仅考虑冲突情况:即一个边长出现了多次(如果仅仅出现了一次就无须考虑,直接无缝的塞进适应的位置即可)。
因而仅仅需要考虑连成片的图(联通块情况)。对于任意可行解,都有同一长度作为宽度不出现超过1次。
对于一个图,都会有如下设定:
1、每条边最多只能做一次“宽”,因而如果出现了多条边指向这个点的话,将会必然增加deg-1次高(因为每个边长作为宽度最多只能出现一次)
2、对于树状情况,若果有X个长宽组成一个联通块,则必然至少包括X-1个边,讨论上条定理,必然会有一个边应当作为高出现,因而建议选择最大的。
重新梳理下思路:
1、考虑不同联通块,由于不存在相同的宽度,因此可以仅单独讨论其对答案的贡献(因为互相穿插互不影响)
2、对于同一个联通块,应当认为仅仅存在两种情况——即树或者树多一条边:
考虑每个点都是一个边长,每条边都是一个矩形,
若有树则是,n个不同的点对应n-1个矩形,则认为有n-1个不同的长度分别担任“成为宽度”的重任;
若有多一条边,则认为n个点对应n个矩形,则有正好n个不同的长度分别担任“成为宽度”的重任;
在多一条边,则认为,n个不同的长度,要出n+1个矩形(考虑必然要有n+1个不同的长度担任“成为宽度”的重任,然额一共只有n,故不存在);
3、对于每个点,如果被多次指向,那么必然应当“最少有size-1次担任“成为高度”的任务“,换句话说,最多成为一次宽度。因此,对于任何一点,都必然为答案贡献(size-1)*val[now].
4、对于每个树,我们可以自由选择”哪个点为起始节点,即不被指向(换句话说,指定任意节点为根)将其点权值贡献给答案“
5、对于树+1条边,参见2,认为“没得选”
最后注意下数据太大,要首先离散化一下。
三、代码
#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
#include<algorithm>
#include<vector>
#include<map>
#include<set>
#include<string.h>
#include<queue> using namespace std; #define ll long long const ll MAXN=;
map<int,int> mapp;
ll n,val[MAXN],vis[MAXN];
vector<int>G[MAXN];
ll deg,maxx;
ll ans; void dfs(int now)
{
if(vis[now])return;
vis[now]=;
ans+=val[now]*(G[now].size()-);
maxx=max(maxx,val[now]);
deg+=G[now].size()-;
for(int i=;i<G[now].size();++i)
{
dfs(G[now][i]);
} } int main()
{
while(cin>>n)
{
mapp.clear();
int id=;
for(int i=;i<=MAXN;++i)G[i].clear();
for(int i=;i<=n;++i)
{
int a,b,aa,bb;
scanf("%d%d",&a,&b);
if(mapp.count(a))aa=mapp[a];
else aa=mapp[a]=id++;
if(mapp.count(b))bb=mapp[b];
else bb=mapp[b]=id++;
val[aa]=a;
val[bb]=b;
G[aa].push_back(bb);
G[bb].push_back(aa);
}
memset(vis,,sizeof(vis));
ans=;
for(int i=;i<id;++i)
{
if(!vis[i])
{
deg=;
maxx=;
dfs(i);
if(deg<)ans+=maxx;
} }
cout<<ans<<endl;
} return ;
}
Highest Tower 18中南多校第一场H题的更多相关文章
- Card Hand Sorting 18中南多校第一场C题
一.题意 随机给你一堆牌(标准扑克牌),之后让你按照: 第一优先规则:所有相同花色的在一起 第二优先规则:所有相同花色的必须按照升序或者降序排列 问,你最少要拿出多少张牌插入到其他的地方以维持这个状况 ...
- 2019年牛客多校第一场 H题XOR 线性基
题目链接 传送门 题意 求\(n\)个数中子集内所有数异或为\(0\)的子集大小之和. 思路 对于子集大小我们不好维护,因此我们可以转换思路变成求每个数的贡献. 首先我们将所有数的线性基的基底\(b\ ...
- 2019年牛客多校第一场B题Integration 数学
2019年牛客多校第一场B题 Integration 题意 给出一个公式,求值 思路 明显的化简公式题,公式是分母连乘形式,这个时候要想到拆分,那如何拆分母呢,自然是裂项,此时有很多项裂项,我们不妨从 ...
- 【2019多校第一场补题 / HDU6578】2019多校第一场A题1001Blank——dp
HDU6578链接 题意 有一串字符串,仅由 {0,1,2,3}\{0, 1, 2, 3\}{0,1,2,3} 组成,长度为 nnn,同时满足 mmm 个条件.每个条件由三个整数组成:l.r.xl.r ...
- Artwork 18年中南多校第一场A
一.题意 对于一个矩阵,若干道命令,每道命令将会把某一段格子涂黑,请问每次涂黑之后矩阵中未被涂黑的块的数量? 二.思路 保存每道命令,并且忠实的执行他,到最后一步开始搜索联通块的数量,并将其保存. 之 ...
- 2014多校第一场J题 || HDU 4870 Rating(DP || 高斯消元)
题目链接 题意 :小女孩注册了两个比赛的帐号,初始分值都为0,每做一次比赛如果排名在前两百名,rating涨50,否则降100,告诉你她每次比赛在前两百名的概率p,如果她每次做题都用两个账号中分数低的 ...
- 2014多校第一场 E 题 || HDU 4865 Peter's Hobby (DP)
题目链接 题意 : 给你两个表格,第一个表格是三种天气下出现四种湿度的可能性.第二个表格是,昨天出现的三种天气下,今天出现三种天气的可能性.然后给你这几天的湿度,告诉你第一天出现三种天气的可能性,让你 ...
- 2014多校第一场 I 题 || HDU 4869 Turn the pokers(费马小定理+快速幂模)
题目链接 题意 : m张牌,可以翻n次,每次翻xi张牌,问最后能得到多少种形态. 思路 :0定义为反面,1定义为正面,(一开始都是反), 对于每次翻牌操作,我们定义两个边界lb,rb,代表每次中1最少 ...
- 2014多校第一场D题 || HDU 4864 Task (贪心)
题目链接 题意 : 用N台机器,M个任务,每台机器都有一个最大工作时间和等级,每个任务有一个需要工作时间和一个等级.如果机器完成一个任务要求是:机器的工作时间要大于等于任务的时间,机器的等级要大于等于 ...
随机推荐
- DIV三列同行
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- cookie乱码处理 示例
package com.log; import java.io.IOException; import java.net.URLEncoder; import java.util.ArrayList; ...
- CSS实现多重边框和内凹圆角
CSS实现多重边框 <!DOCTYPE html> <html lang="zh-cn"> <head> <meta charset=&q ...
- Unity3D 调用Android与IOS的剪贴板
Unity3D剪贴板 最近遇到一个需要调用Android与IOS设备本身剪贴板的需求,就是在Unity中,要将文本复制到设备本身的剪贴板中,然后在其他应用程序中都能粘贴. 最开始在网上查到的方式是使用 ...
- 【转】【MATLAB】模拟和数字低通滤波器的MATLAB实现
原文地址:http://blog.sina.com.cn/s/blog_79ecf6980100vcrf.html 低通滤波器参数:Fs=8000,fp=2500,fs=3500,Rp=1dB,As= ...
- Azure进阶攻略 | VS2015和Azure,想要在一起其实很容易
下雨天,巧克力和音乐很配…… 大冬天,男神和捧在手里的奶茶很配…… 「驴牌」的包包,和女神的全部衣服都配…… 对于「王首富」,容易实现的小目标和一个亿是绝配…… …… 醒醒吧!!这些事情和每天只会写代 ...
- 第四章 T-SQL编程
1.前言->此T-SQL编程是基于sql server开发环境->关键字:T-SQL编程:游标:视图和索引 2.T-SQL编程基础->标识符:常规标识符必须以汉字.字母.下划线_.@ ...
- 洛谷 P1080 国王游戏
题目描述 恰逢 H 国国庆,国王邀请 n 位大臣来玩一个有奖游戏.首先,他让每个大臣在左.右手上面分别写下一个整数,国王自己也在左.右手上各写一个整数.然后,让这 n 位大臣排成一排,国王站在队伍的最 ...
- Cocos2d-x手机游戏开发必备C++语言基础
http://edu.51cto.com/course/course_id-1380-page-1.html
- Codeforces 760A Petr and a calendar
题目链接:http://codeforces.com/problemset/problem/760/A 题意:日历需要多少列. #include <bits/stdc++.h> using ...