HDU4467 Graph【轻重点维护】
HDU4467 Graph
题意:
给出一张染色图,\(n\)个点每个点是黑色或者白色,\(m\)条带权边,\(q\)次操作,有两种操作:
- 改变一个点的颜色
- 问所有边中两个端点的颜色为给定情况的边权和是多少
题解:
首先因为有重边,所以先把重边合并一下
然后按每个点的度数是否大于\(\sqrt{边总数}\),把点分轻点和重点,同时记录所有三种询问情况的答案
在图中,重点我们保存其所有连的重点的边,轻点我们保存其所有连出去的边
显然重点不会超过\(sqrt{边总数}\)个,且重点和轻点所连出去的边不会超过\(sqrt{边总数}\)条
每个重点要记录它连出去的到达黑点的边的总权值和到达白点的边的总权值
对于每次修改操作,分轻重点分别维护
- 如果修改的是轻点,那么直接暴力修改答案
- 如果是重点,利用保存的连出去的边到达的两种颜色的权值和更新答案
同时每次修改一个点,需要更新其连的重点的两个总权值数据
对于查询操作直接输出记录的答案即可
查询复杂度\(O(1)\)
修改复杂度\(O(sqrt{边总数})\)
总时间复杂度为\(O(q sqrt{边总数})\)
只给了\(32MB\)的空间,很容易爆内存
//#pragma GCC optimize("O3")
//#pragma comment(linker, "/STACK:1024000000,1024000000")
#include<bits/stdc++.h>
using namespace std;
function<void(void)> ____ = [](){ios_base::sync_with_stdio(false); cin.tie(0); cout.tie(0);};
const int MAXN = 1e5+7;
typedef long long int LL;
int n,m,col[MAXN],deg[MAXN];
LL vtot[3],val[2][MAXN];
bool heavy[MAXN];
vector<pair<int,LL>> G[MAXN];
char op[10];
void solvequery(){
scanf("%s",op);
if(op[0]=='A'){
int x, y;
scanf("%d %d",&x,&y);
printf("%I64d\n",vtot[x+y]);
}
else{
int x; scanf("%d",&x);
if(heavy[x]){
vtot[1+col[x]] -= val[1][x]; vtot[0+col[x]] -= val[0][x];
vtot[1+(col[x]^1)] += val[1][x]; vtot[0+(col[x]^1)] += val[0][x];
}
else{
for(auto e : G[x]){
vtot[col[x]+col[e.first]] -= e.second;
vtot[(col[x]^1)+col[e.first]] += e.second;
}
}
for(auto e : G[x]){
if(!heavy[e.first]) continue;
val[col[x]][e.first] -= e.second;
val[col[x]^1][e.first] += e.second;
}
col[x] ^= 1;
}
}
pair<pair<int,int>,LL> vec[MAXN];
void solve(int kase){
for(int i = 1; i <= n; i++){
scanf("%d",&col[i]);
G[i].clear();
val[0][i] = val[1][i] = deg[i] = 0;
}
vtot[0] = vtot[1] = vtot[2] = 0;
int tot = 0;
for(int i = 1; i <= m; i++){
int u, v, w; scanf("%d %d %d",&u,&v,&w);
if(u>v) u ^= v ^= u ^= v;
vec[++tot] = make_pair(make_pair(u,v),w);
}
sort(vec+1,vec+1+tot);
int nt = 1;
for(int i = 2; i <= tot; i++){
if(vec[i].first==vec[nt].first) vec[nt].second += vec[i].second;
else vec[++nt] = vec[i];
}
for(int i = 1; i <= nt; i++) deg[vec[i].first.first]++, deg[vec[i].first.second]++;
int up = sqrt(nt);
for(int i = 1; i <= n; i++) heavy[i] = deg[i]>=up;
for(int i = 1; i <= nt; i++){
auto &e = vec[i];
int u = e.first.first, v = e.first.second;
LL w = e.second;
if(heavy[u]){
if(heavy[v]) G[u].push_back(make_pair(v,w));
val[col[v]][u] += w;
}
else G[u].push_back(make_pair(v,w));
if(heavy[v]){
if(heavy[u]) G[v].push_back(make_pair(u,w));
val[col[u]][v] += w;
}
else G[v].push_back(make_pair(u,w));
vtot[col[u]+col[v]] += w;
}
int q; scanf("%d",&q);
printf("Case %d:\n",kase);
while(q--) solvequery();
}
int main(){
int kase = 0;
while(scanf("%d %d",&n,&m)!=EOF) solve(++kase);
return 0;
}
HDU4467 Graph【轻重点维护】的更多相关文章
- HDU4467:Graph(点的度数分块)
传送门 题意 给出一张n个点m条边的无向图,点的颜色为0/1,每次有两种操作: 1.Asksum x y,查询两点颜色为x和y的边的权值之和 2.Change x,将x颜色取反 分析 最直接的做法是每 ...
- hdu4467 Graph
Graph Problem Description P. T. Tigris is a student currently studying graph theory. One day, when h ...
- Nebula Graph 在企查查的应用
本文首发于 Nebula Graph Community 公众号 背景 企查查是企查查科技有限公司旗下的一款企业信用查询工具,旨在为用户提供快速查询企业工商信息.法院判决信息.关联企业信息.法律诉讼. ...
- 2013 ACM/ICPC Asia Regional Online —— Warmup2
HDU 4716 A Computer Graphics Problem 水题.略 HDU 4717 The Moving Points 题目:给出n个点的起始位置以及速度矢量,问任意一个时刻使得最远 ...
- scala知识点(一)
1.drop,dropRight,dropWhile drop: drop(n: Int): List[A] 丢弃前n个元素,返回剩下的元素 dropRight: dropRight(n: Int): ...
- GraphX 图数据建模和存储
背景 简单分析一下GraphX是怎么为图数据建模和存储的. 入口 能够看GraphLoader的函数. def edgeListFile( sc: SparkContext, path: String ...
- [Docker01] The Docker Road
The Docker Road Docker是什么? Docker是docker容器为资源分隔和调度的基本单位,封装整个软件运行时环境,为开发者和系统管理员设计的,用于构建,发布和运行分布式应用的平台 ...
- [源码解析] Pytorch 如何实现后向传播 (2)---- 引擎静态结构
[源码解析] Pytorch 如何实现后向传播 (2)---- 引擎静态结构 目录 [源码解析] Pytorch 如何实现后向传播 (2)---- 引擎静态结构 0x00 摘要 0x01 Engine ...
- 转债---Pregel: A System for Large-Scale Graph Processing(译)
转载:http://duanple.blog.163.com/blog/static/70971767201281610126277/ 作者:Grzegorz Malewicz, Matthew ...
随机推荐
- 解放双手,markdown文章神器,Typora+PicGo+七牛云图床实现自动上传图片
本文主要分享使用Typora作为Markdown编辑器,PicGo为上传图片工具,使用七牛云做存储来解放双手实现图片的自动化上传与管理.提高写作效率,提升逼格.用过 Markdown 的朋友一定会深深 ...
- 记一次使用Asp.Net Core WebApi 5.0+Dapper+Mysql+Redis+Docker的开发过程
#前言 我可能有三年没怎么碰C#了,目前的工作是在全职搞前端,最近有时间抽空看了一下Asp.net Core,Core版本号都到了5.0了,也越来越好用了,下面将记录一下这几天以来使用Asp.Net ...
- Js中函数式编程的理解
函数式编程的理解 函数式编程是一种编程范式,可以理解为是利用函数把运算过程封装起来,通过组合各种函数来计算结果.函数式编程与命令式编程最大的不同其实在于,函数式编程关心数据的映射,命令式编程关心解决问 ...
- selenium爬虫 | 爬取疫情实时动态(二)
'''@author:Billie更新说明:1-28 17:00 项目开始着手,spider方法抓取到第一条疫情数据,save_data_csv方法将疫情数据保存至csv文件1-29 13:12 目标 ...
- 在IDEA中通过Module管理多个项目
你身边有没有这种顽固的Eclipse忠实用户:IDEA不能一个窗口管理多个项目!太不方便了! 对于一个窗口同时管理多个项目的需求,在我们日常开发时候是经常需要的.尤其当我们在分布式环境下,在一个窗口中 ...
- Oracle 索引原理分析
索引是一种允许直接访问数据表中某一数据行的树型结构,为了提高查询效率而引入,是一个独立于表的对象,可以存放在与表不同的表空间中.索引记录中存有索引关键字和指向表中数据的指针(地址).对索引进行的I/O ...
- yml文件中${DB_HOST:localhost}的含义
引自:https://blog.csdn.net/chen462488588/article/details/109057342 今天学习eladmin项目中看到application-dev.yml ...
- uni-app开发经验分享七: 有关列表数据下拉加载方法的解析及记录
在使用uni.request获取后台数据时,我们往往碰到一个问题,列表的懒加载及数据实时更新,这里记录下我制作这类功能的方法. 问题描述:后台返回数据,前端需要进行10个为一组来分页,先显示前10个, ...
- Mybatis SQL映射文件详解
Mybatis SQL映射文件详解 mybatis除了有全局配置文件,还有映射文件,在映射文件中可以编写以下的顶级元素标签: cache – 该命名空间的缓存配置. cache-ref – 引用其它命 ...
- 让绝对定位的div居中
最近看到一个问题就是让绝对定位的div居中,在尝试了top:50%:left:50%:后发现,居中是有问题的并不是想象中的样子 需要再加两句margin-top:-盒子高度的一般px margin- ...