「10.17-10.18」liu_runda’s模拟
暂咕
$day1$
A. 位运算
分类讨论,贡献分离。
B. 集合论
维护类似时间戳的东西
C. 连连看
考场思路太局限了,考虑容斥。
我们可以看出两个方块能作出贡献,实际上是一个极大联通块(白块)所连节点,
然后我们就可以乱搞了
因为块会重复计算,容斥即可
有点懒,所以懒得细写了....
#include<bits/stdc++.h>
#define int long long
#define MAXN 1101
using namespace std;
int read(){
char c=getchar();int ff=1;int x=0;
while(c<'0'||c>'9'){if(c=='-')ff=-1;c=getchar();}
while(c>='0'&&c<='9'){x=(x<<1)+(x<<3)+(c^48);c=getchar();}
return x*ff;
}
int dex[5]={-1,1,0,0};
int dey[5]={0,0,-1,1};
int a[MAXN][MAXN];
//int kt[4][MAXN*MAXN*2];
const int mod=23333333;
/*struct node{
int head[mod];int tot=0;int nxt[mod];int to[mod];int val[mod];
int find(int x){
int me=x%mod;
for(int i=head[me];i;i=nxt[i]){
if(to[i]==x){return val[i];}
}
return 0;
}
void init(){
for(int i=1;i<=tot;++i)nxt[i]=0;
tot=0;
}
void insert(int x){
int me=x%mod;
for(int i=head[me];i;i=nxt[i]){
if(to[i]==x){val[x]++;return ;}
}
tot++;
to[tot]=x;head[me]=tot;val[tot]++;
}
void erase(int x){
int me=x%mod;
for(int i=head[me];i;i=nxt[i]){
to[i]=0;val[i]=0;
}
head[me]=0;
return ;
}
}T1,T2,T3;*/
int f[MAXN][MAXN][5];
int vis[MAXN][MAXN];
vector<pair<int,int> >v[MAXN*MAXN*2];int ans=0;
void work(int x){
if(!v[x].size())return ;
//printf("x=%lld\n",x);
map<int,int>T4,T1,T2,T3;
//kt[1][0]=0;kt[2][0]=0;kt[3][0]=0;
for(int i=0;i<v[x].size();++i){
int tox=v[x][i].first;int toy=v[x][i].second;
int k=1;for(k=1;k<=5;++k)if(f[tox][toy][k]==0)break;k--;
for(int j=1;j<=k;++j){
/*
ans+=T1.find(f[tox][toy][j]);
T1.insert(f[tox][toy][j]);
*/
ans+=T1[f[tox][toy][j]];
T1[f[tox][toy][j]]++;
//kt[1][++kt[1][0]]=f[tox][toy][j];
}
for(int j=1;j<=k;++j){
unsigned long long base=f[tox][toy][j];
for(int w=1;w<j;++w){
base=base*10000007ll+f[tox][toy][w];
/*
ans-=T2.find(base);
T2.insert(base);
kt[2][++kt[2][0]]=base;
*/
ans-=T2[base];
T2[base]++;
}
}
for(int j=1;j<=k;++j){
unsigned long long base=f[tox][toy][j];
for(int w=1;w<j;++w){
base=base*10000007ll+f[tox][toy][w];
for(int z=1;z<w;++z){
base=base*10000007ll+f[tox][toy][z];
/*
ans+=T3.find(base);
T3.insert(base);
*/ ans+=T3[base];
T3[base]++;
// kt[3][++kt[3][0]]=base;
}
}
}
if(k==4){
unsigned long long base=f[tox][toy][4]*10000007ll;
base=f[tox][toy][3]+base*10000007ll;
base=f[tox][toy][2]+base*10000007ll;
base=base*100000007ll+f[tox][toy][1];
ans-=T4[base];
T4[base]++;
}
}
/*
for(int i=1;i<=kt[1][0];++i){T1.erase(kt[1][i]);}
for(int i=1;i<=kt[2][0];++i){T2.erase(kt[2][i]);}
for(int i=1;i<=kt[3][0];++i){T3.erase(kt[3][i]);}
T1.init();T2.init();T3.init();
*/
}
queue<pair<int,int> >q;int n,m;
void puss(int tox,int toy,int sum){
int j=0;
for(j=1;j<=4;++j){if(f[tox][toy][j]==0)break;}
f[tox][toy][j]=sum;
}
int cnt=0;
pair<int,int>st[MAXN*MAXN];
void BFS(int x,int y){
int sss=0;
q.push(make_pair(x,y));vis[x][y]=1;
while(!q.empty()){
int mx=q.front().first;
int my=q.front().second;
q.pop();
for(int i=0;i<=3;++i){
int tox=mx+dex[i];int toy=my+dey[i];
if(tox<1||tox>n)continue;
if(toy<1||toy>m)continue;
if(a[tox][toy]==0&&vis[tox][toy]==0){
vis[tox][toy]=1;
q.push(make_pair(tox,toy));
}
else if(a[tox][toy]!=0&&vis[tox][toy]==0){
vis[tox][toy]=1;
st[++sss]=make_pair(tox,toy);
puss(tox,toy,cnt);
}
}
}
for(int i=1;i<=sss;++i){
int tox=st[i].first;int toy=st[i].second;
vis[tox][toy]=0;
}
sss=0;
}
int look(int x1,int y1,int x2,int y2){
for(int i=1;i<=4;++i){
if(f[x1][y1][i]==0)continue;
for(int j=1;j<=4;++j){
if(f[x2][y2][j]==0)continue;
if(f[x1][y1][i]==f[x2][y2][j])return 0;
}
}
return 1;
}
void QAQ(){
int sum=0;
for(int i=1;i<=n;++i){
for(int j=1;j<=m;++j){
if(a[i][j]==0)continue;
for(int k=0;k<=3;++k){
int tox=i+dex[k];int toy=j+dey[k];
if(tox<=0||tox>n)continue;
if(toy<=0||toy>m)continue;
if(a[i][j]!=a[tox][toy])continue;
sum+=look(i,j,tox,toy);
}
}
}
ans+=sum/2;
}
int mx=0;int k;
signed main(){
//freopen("link6.in","r",stdin);
n=read();m=read();k=read();
for(int i=1;i<=n;++i)
for(int j=1;j<=m;++j){
a[i][j]=read();
if(a[i][j]==0)continue;
v[a[i][j]].push_back(make_pair(i,j));
mx=max(a[i][j],mx);
}
for(int i=1;i<=n;++i){
for(int j=1;j<=m;++j){
if(!vis[i][j]&&a[i][j]==0){
cnt++;
BFS(i,j);
}
}
}
for(int i=1;i<=mx;++i){work(i);}
QAQ();
printf("%lld\n",ans);
}
/*
3 3 4
1 0 2
2 3 0
0 0 2
*/
$day2$
A. 串串香
$hash$即可
B. 糊涂图
还没改出来QAQ....
C. 木叶下
树上直径,再用上$lca$即可
我们维护若干数组
$dp_{i}$表示从$x$的父亲不经过$x$的最大路径
$g_{i,4}$表示$x$的几个长链的儿子
$gofa_{i}$表示向$fa$的最长路径
$dis$是对于$dp$的倍增数组
然后根据数组定义打就没了
#include<bits/stdc++.h>
#define int long long
#define MAXN 210005
using namespace std;
int read(){
char c=getchar();int ff=1;int x=0;
while(c<'0'||c>'9'){if(c=='-')ff=-1;c=getchar();}
while(c>='0'&&c<='9'){x=(x<<1)+(x<<3)+(c^48);c=getchar();}
return x*ff;
}
int anss,diss[MAXN];
int dp[MAXN];//从x的父亲不经过x的最大路径
int fa[MAXN][25];
int dis[MAXN][25];
int g[MAXN][4];//从x到x的子树的最大路径
int son[MAXN][4];
int deep[MAXN];
int gofa[MAXN];//向fa走的最长路径
struct node{int to,n;}e[MAXN*2];int tot,head[MAXN];
void add(int u,int v){e[++tot].to=v;e[tot].n=head[u];head[u]=tot;}
void pianfen(int x,int fa){
for(int i=head[x];i;i=e[i].n){
int to=e[i].to;
if(to==fa)continue;
pianfen(to,x);
anss=max(anss,diss[x]+diss[to]+1);
diss[x]=max(diss[to]+1,diss[x]);
}
}
int n,m;
void DP(int x,int fa){
priority_queue<pair<int,int> >q;
g[x][1]=1;
for(int i=head[x];i;i=e[i].n){
int to=e[i].to;
if(to==fa)continue;
DP(to,x);
q.push(make_pair(g[to][1]+1,to));
//printf("psg=%lld x=%lld to=%lld\n",g[to][1]+1,x,to);
}
int th=1;
while(!q.empty()){
g[x][th]=q.top().first;
son[x][th]=q.top().second;
q.pop();
//printf("g[%lld][%lld]=%lld %lld\n",x,th,g[x][th],son[x][th]);
th++;
if(th==4)break;
}
}
void DFS2(int x,int fa){
for(int i=head[x];i;i=e[i].n){
int to=e[i].to;
if(to==fa)continue;
if(son[x][1]!=to)dp[to]=max(1ll,g[x][1]);
else dp[to]=max(1ll,g[x][2]);
//printf("dp[%lld]=%lld\n",to,dp[to]);
DFS2(to,x);
}
}
void jia_swaproot(int x,int fa){
for(int i=head[x];i;i=e[i].n){
int to=e[i].to;
if(to==fa)continue;
gofa[to]=max(gofa[x]+1,dp[to]+1);
jia_swaproot(to,x);
}
}
void DFS(int x,int faa){
//printf("xxx=%lld\n",x);
for(int i=head[x];i;i=e[i].n){
int to=e[i].to;
if(to==faa)continue;
fa[to][0]=x;
deep[to]=deep[x]+1;
dis[to][0]=dp[to];
//printf("dis[%lld]=%lld\n",to,dis[to][0]);
for(int j=1;j<=19;++j){
if(fa[to][j-1]==0)break;
fa[to][j]=fa[fa[to][j-1]][j-1];
dis[to][j]=max(dis[to][j-1],dis[fa[to][j-1]][j-1]);
}
DFS(to,x);
}
}
int Lca(int x,int y){
int maxn=0;
if(deep[x]<deep[y])swap(x,y);
int yuanx=x;int yuany=y;
//printf("x=%lld y=%lld\n",x,y);
for(int i=19;i>=0;--i){
if(deep[fa[x][i]]>=deep[y]){
maxn=max(dis[x][i]-1,maxn);
//printf("maxn=%lld %lld\n",maxn,dis[x][i]);
x=fa[x][i];
}
}
if(x==y){
maxn=max(maxn,g[yuanx][1]-1);
maxn=max(gofa[x]-1,maxn);
//printf("go=%lld %lld\n",gofa[x]-1,x);
return maxn;
}
for(int i=19;i>=0;--i){
if(fa[x][i]!=fa[y][i]){
maxn=max(dis[x][i]-1,maxn);
maxn=max(dis[y][i]-1,maxn);
x=fa[x][i],y=fa[y][i];
}
}
int lca=fa[x][0];
for(int j=1;j<=3;++j){
if(son[lca][j]==x||son[lca][j]==y)continue;
maxn=max(maxn,g[lca][j]-1);
break;
}
maxn=max(maxn,gofa[lca]-1);
maxn=max(maxn,g[yuanx][1]-1);maxn=max(maxn,g[yuany][1]-1);
return maxn;
}
signed main(){
//freopen("myx.in","r",stdin);
//freopen("wwb.out","w",stdout);
n=read();
for(int i=1;i<=n-1;++i){
int u=read();int v=read();
add(u,v);add(v,u);
}
deep[1]=1;
pianfen(1,0);
DP(1,0);
DFS2(1,0);
jia_swaproot(1,0);
DFS(1,0); anss++;
if(anss%2==1)anss/=2,anss++;
else anss/=2; m=read();
for(int i=1;i<=m;++i){
int u=read();int v=read();
if(u==v){
printf("%lld\n",anss);
continue;
}
int ans=Lca(u,v);
printf("%lld\n",ans);
}
}
「10.17-10.18」liu_runda’s模拟的更多相关文章
- 【record】10.17..10.23
.
- 对于最近的一些日常总结by520(17.10.18)
---天天考试,各种题型都有,学到了很多新的知识,也发现了自己的许多不足---1.首先,自己的搜索需要加强,特别是广搜,10.18的T1裸广搜没有做对.2.数学的思维和一些逻辑问题需要加强,然后就是要 ...
- GitHub 公布 2021 Top 10 博文「GitHub 热点速览」
作者:HelloGitHub-小鱼干 2021 年在这周彻底同我们告别了,在本周的「News 快读」模块你可以看到过去一年 GitHub 的热门文章,其中有我们熟悉的可能让很多程序员"失业& ...
- Ubuntu网络配置IP和DNS等,适用于14.04,16.04和17.10
本文主要介绍Ubuntu系统的网络设置,包括IP,DNS和主机名等,适用于14.04,16.04和17.10等版本 =============== 完美的分割线 ================ = ...
- NOIP模拟赛 17.10.10
初次见面(firstmeet)[题目背景]雾之湖边,静得可怕.露米娅出神凝望.黑白连衣裙,像极了绽放的墨黑和洁白的莲.身边的雾之湖,倒映着血色天空.酒红的双眸,映照一切.低声浅笑,双臂伸直,她悄无声息 ...
- Noip模拟79 2021.10.17(题目名字一样)
T1 F 缩点缩成个$DAG$,然后根据每个点的度数计算期望值 1 #include<cstdio> 2 #include<cstring> 3 #include<vec ...
- 背水一战 Windows 10 (17) - 动画: ThemeTransition(过渡效果)
[源码下载] 背水一战 Windows 10 (17) - 动画: ThemeTransition(过渡效果) 作者:webabcd 介绍背水一战 Windows 10 之 动画 ThemeTrans ...
- 发现struct proc_dir_entry内核3.10.17移到internal中去了,倒
struct proc_dir_entry 原:2.6.38.8 在#include <linux/proc_fs.h> 现:3.10.17 在fs/proc/internal.h:str ...
- [CareerCup] 17.10 Encode XML 编码XML
17.10 Since XML is very verbose, you are given a way of encoding it where each tag gets mapped to a ...
随机推荐
- ppt技巧一四步法调整段落排版
声明:本文所有截图来源于网易云课堂--<和秋叶一起学PPT>,仅作为个人复习之用,特此声明!
- 改善c++程序的150个建议(读后总结)-------0-9
0. 不要让main 函数返回 void 入口函数main()返回类型应该为 int, 即程序结束时return 0 表示程序正常返回,函数结束时 return -1 值表示程序异常返回, 如果不显式 ...
- QFNU-ACM 2019.5.23组队赛 2019山东省赛复现
A.Calandar 题意:一年12个月,一个月30天,5天一周,已知某天的年月日星期数,求所给年月日的星期数是多少 思路:直接进行计算,其实每个月每年都是等长度的就使得计算的时候忽略年月,可以直接进 ...
- 【BUAA软工】Visual Lab Online——功能规格说明书
项目 内容 班级:北航2020春软件工程 博客园班级博客 作业:明确和撰写软件的功能规格说明书 功能规格说明书 当前版本:v1.0 修订历史: 版本号 修订时间 修订说明 v1.0 2020/04/0 ...
- 关于flask的模板注入的学习
flask模板注入的学习 关于flask模版注入,之前不太理解,看了很多文章才弄懂,主要原理就是渲染函数的参数用户可控就造成了模板注入 就会使用户构造恶意的代码进行逃逸从而进行攻击 flask模板渲染 ...
- 使用 Yarn workspace,TypeScript,esbuild,React 和 Express 构建 K8S 云原生应用(一)
本文将指导您使用 K8S ,Docker,Yarn workspace ,TypeScript,esbuild,Express 和 React 来设置构建一个基本的云原生 Web 应用程序. 在本教程 ...
- systemd服务的输出重定向到指定文件
有一种更优雅的方法可以解决systemd输出到指定文件而非/var/log/message,需要使用systemd参数与rsyslog过滤器.并指示syslog过滤器按程序名称拆分其输出. syste ...
- [Python] 爬虫系统与数据处理实战 Part.1 静态网页
爬虫技术基础 HTTP/HTTPS(7层):应用层,浏览器 SSL:加密层,传输层.应用层之间 TCP/IP(4层):传输层 数据在传输过程中是加密的,浏览器显示的是解密后的数据,对爬虫没有影响 中间 ...
- 【转载】CentOS 7自动以root身份登录gnome桌面 操作系统开机后自动登录到桌面 跳过GDM
CentOS 7自动以root身份登录gnome桌面 ################### #cd /etc/gdm ]# cat custom.conf# GDM configuration st ...
- php-round()四舍六入
今天被问到了四舍六入的问题,好吧,第一次听说.后来查询之后说是银行家算法用的 摘自PHP官方文档.http://php.net/manual/zh/function.round.php (PHP 4, ...