博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
D. Fish eating fruit
阅读量:5290 次
发布时间:2019-06-14

本文共 2411 字,大约阅读时间需要 8 分钟。

题:https://nanti.jisuanke.com/t/41403

题意:求任意俩点之间距离之和模3后的三个结果的总数(原距离之和)

第一种做法:

树形dp

 

#include
using namespace std;#define pb push_backtypedef long long ll;const int M=1e4+4;const int mod=1e9+7;struct node{ int v; ll w;};ll C[M][3],S[M][3],ans[M];//C[i][j]:表示以i为根,然后路径消耗取模后为j的路径数//S[i][j]:表示以i为根,路径消耗取模后为j的路径总消耗 vector
e[M];;void dfs(int u,int f,ll pre){ C[u][0]=C[u][1]=C[u][2]=0; S[u][0]=S[u][1]=S[u][2]=0; int len=e[u].size(); for(int i=0;i
View Code

 第二种做法:

点分治

#include
using namespace std;typedef long long ll;const int M=2e4+4;const ll mod=1e9+7;struct node{ int v,nextt; ll w;}e[M<<1];ll sum[4],disnum[4],dissum[4];int head[M],vis[M],sz[M],maxv[M],tot,n,maxx,root;void addedge(int u,int v,ll w){ e[tot].v=v; e[tot].nextt=head[u]; e[tot].w=w; head[u]=tot++;}void dfssz(int u,int f){ maxv[u]=0; sz[u]=1; for(int i=head[u];~i;i=e[i].nextt){ int v=e[i].v; if(v==f||vis[v]) continue; dfssz(v,u); sz[u]+=sz[v]; maxv[u]=max(maxv[u],sz[v]); }}void dfsroot(int r,int u,int f){ maxv[u]=max(maxv[u],sz[r]-sz[u]); if(maxx>maxv[u]){ maxx=maxv[u]; root=u; } for(int i=head[u];~i;i=e[i].nextt){ int v=e[i].v; if(v==f||vis[v]) continue; dfsroot(r,v,u); }}void dfsdis(int u,int f,ll d){// if(f!=-1&&d!=0) disnum[d%3]++; disnum[d%3]%=mod; dissum[d%3]+=d; dissum[d%3]%=mod; for(int i=head[u];~i;i=e[i].nextt){ int v=e[i].v; if(vis[v]||v==f) continue; dfsdis(v,u,(d+e[i].w)%mod); }}void cal(int u,ll d,int flag){ for(int i=0;i<3;i++) dissum[i]=disnum[i]=0; dfsdis(u,-1,d); for(int i=0;i<3;i++) for(int j=0;j<3;j++){ int t=(i+j)%3; sum[t]=(sum[t]+flag*((disnum[i]*dissum[j]%mod+disnum[j]*dissum[i]%mod)%mod)%mod+mod)%mod; }}void solve(int u){ maxx=n; dfssz(u,-1); dfsroot(u,u,-1); cal(root,0ll,1);//+ vis[root]=1; for(int i=head[root];~i;i=e[i].nextt){ int v=e[i].v; if(vis[v]) continue; cal(v,e[i].w,-1); solve(v); }}int main(){ while(~scanf("%d",&n)){ sum[0]=sum[1]=sum[2]=0; tot=0; for(int i=0;i<=n;i++) head[i]=-1,vis[i]=0;; for(int i=1;i
View Code

 

转载于:https://www.cnblogs.com/starve/p/11521143.html

你可能感兴趣的文章
BootStrap2学习日记2--将固定布局换成响应式布局
查看>>
关于View控件中的Context选择
查看>>
2018icpc徐州OnlineA Hard to prepare
查看>>
R语言-rnorm函数
查看>>
Spark的启动进程详解
查看>>
Java 字符终端上获取输入三种方式
查看>>
javascript 简单工厂
查看>>
java调用oracle存储过程,返回结果集
查看>>
使用命令创建数据库和表
查看>>
数据库的高级查询
查看>>
HttpClient(一)-- HelloWorld
查看>>
dump调试函数
查看>>
Android 利用Sharp样式设置文本框EditText圆角形状
查看>>
[YTU]_2443 ( C++习题 复数类--重载运算符3+)
查看>>
sdut_1189
查看>>
归并排序
查看>>
机器视觉:SSD Single Shot MultiBox Detector
查看>>
走遍美国 —— 各州及其别名
查看>>
国内外免费电子书(数学、算法、图像、深度学习、机器学习)
查看>>
狄利克雷过程(Dirichlet Process)
查看>>