货物收集

二分答案.复杂度\(O(n\log n)\).

货物分组

费用提前计算的思想,考虑用一个新的箱子来装货物会发生什么.

显然费用会加上后面的所有货物的总重.

\(60\)分的\(O(n^2)\)DP代码:

#include<bits/stdc++.h>
#define LL long long
const int SIZE=100005,INF=0x3F3F3F3F;
int n;
LL W,A[SIZE],sum[SIZE];
LL DP[SIZE]; using std::max;
using std::min; struct Seg_Tree
{
#define LC(x) (x<<1)
#define RC(x) (x<<1|1)
#define Mid ((L+R)>>1)
LL Max[SIZE*4],Min[SIZE*4];
void push_up(int x)
{
Max[x]=max(Max[LC(x)],Max[RC(x)]);
Min[x]=min(Min[LC(x)],Min[RC(x)]);
}
void Build(int x,int L,int R)
{
if(L==R){Max[x]=Min[x]=A[L];return;}
Build(LC(x),L,Mid);
Build(RC(x),Mid+1,R);
push_up(x);
}
LL Query_Max(int x,int L,int R,int X,int Y)
{
if(L>Y||R<X)return -INF;
if(L>=X&&R<=Y)return Max[x];
return max(Query_Max(LC(x),L,Mid,X,Y),Query_Max(RC(x),Mid+1,R,X,Y));
}
LL Query_Min(int x,int L,int R,int X,int Y)
{
if(L>Y||R<X)return INF;
if(L>=X&&R<=Y)return Min[x];
return min(Query_Min(LC(x),L,Mid,X,Y),Query_Min(RC(x),Mid+1,R,X,Y));
}
}T; int main()
{
scanf("%d%lld",&n,&W);
for(int i=1;i<=n;i++)
{
scanf("%lld",&A[i]);
sum[i]=sum[i-1]+A[i];
}
T.Build(1,1,n);
memset(DP,0x3F,sizeof(DP));
DP[0]=0;
for(int i=1;i<=n;i++)
for(int k=i-1;k>=0&&sum[i]-sum[k]<=W;k--)
DP[i]=min(DP[i],DP[k]+sum[n]-sum[k]+T.Query_Max(1,1,n,k+1,i)-T.Query_Min(1,1,n,k+1,i));
printf("%lld",DP[n]);
return 0;
}

地形计算

无向图三元环/四元环的套路题吧.由于我太菜了,还去现学了三/四元环.

[笔记] 三元环 && 四元环计数 - LuitaryiJack的博客园

三/四元环的统计主要思想是Meet in the Middle,也就是把一个环拆成两个部分.从一个点开始标记环的一半,然后再尝试匹配另外一半.如果在尝试匹配的过程中遇到了一个标记过的点,那么这两半就可以拼成一个环.

(此处应有BGMThe Middle)

这么来看,时间复杂度是\(O(n^2)\)的,但是如果按照某种顺序来找环的话,时间复杂度可以降到\(O(m \sqrt{m})\).

我们可以按以下规则给所有点排名:

  1. 度数小的节点排在度数大的节点的前面.
  2. 度数相同的节点,编号小的排在前面.

然后,给每一条无向边定向.

  • 如果寻找三元环,从排名大的连向排名小的.
  • 如果寻找四元环,从排名小的连向排名大的.

最后则统计答案,按照上面的规则定向后,每一个环只会被统计一次.

  • 如果寻找三元环,则对于每一个\(u\),标记它的出点\(v\).然后枚举出点\(v\),再枚举\(v\)的出点\(w\),如果\(w\)被标记,则\((u,v,w)\)形成三元环.

  • 如果寻找四元环,则对于每一个点\(u\),枚举原图中\(u\)的出点\(v\),再枚举重定向图中\(v\)的出点\(w\).标记\(w\).然后再次枚举原图中\(u\)的出点\(v\),枚举重定向图中\(v\)的出点\(w\),如果\(w\)被标记,则形成(可能不止一个)四元环.交换"原图"与"重定向图"的枚举顺序也是可以的.不过,为了保证每个四元环只被计数一次,上述操作必须要求Rank[w]>Rank[u].

本题只是将四元环计数改成了四元环求和,算法本质没有变化,只是在"标记"的时候把个数改成权值和即可.

#include<bits/stdc++.h>
using namespace std;
const int SIZE=100005,Mod=1e9+7;
#define LL long long
#define pb push_back
LL A[SIZE]; int n,m,Deg[SIZE],ID[SIZE],Rnk[SIZE],Cnt[SIZE];
LL Ans,C[SIZE];
vector<int>G1[SIZE],G2[SIZE]; bool cmp(int A,int B)
{
return Deg[A]==Deg[B]?A<B:Deg[A]<Deg[B];
} int main()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++)
scanf("%lld",&A[i]);
int u,v;
for(int i=1;i<=m;i++)
{
scanf("%d%d",&u,&v);
G1[u].pb(v);
G1[v].pb(u);
}
for(int i=1;i<=n;i++)
{
ID[i]=i;
Deg[i]=G1[i].size();
}
sort(ID+1,ID+1+n,cmp);
for(int i=1;i<=n;i++)
Rnk[ID[i]]=i;
for(int u=1;u<=n;u++)
for(int v:G1[u])
if(Rnk[v]>Rnk[u])
G2[u].pb(v);
for(int u=1;u<=n;u++)
{
for(int v:G1[u])
for(int w:G2[v])
if(Rnk[w]>Rnk[u])
{
Ans=(Ans+C[w]+1LL*Cnt[w]*A[v])%Mod;
C[w]=(C[w]+A[u]+A[w]+A[v])%Mod;
++Cnt[w];
}
for(int v:G1[u])
for(int w:G2[v])
if(Rnk[w]>Rnk[u])
{
C[w]=0;
Cnt[w]=0;
}
}
printf("%lld",Ans);
return 0;
}

牛客CSP-S提高组赛前集训营3 赛后总结的更多相关文章

  1. 牛客网CSP-S提高组赛前集训营Round4

    牛客网CSP-S提高组赛前集训营 标签(空格分隔): 题解 算法 模拟赛 题目 描述 做法 \(BSOJ6377\) 求由\(n\)长度的数组复制\(k\)次的数组里每个连续子序列出现数字种类的和 对 ...

  2. 牛客CSP-S提高组赛前集训营4 赛后总结

    复读数组 分成 3 种区间算答案: 一个块内的区间 两个块交界处,长度小于块长的区间 长度不小于块长的区间 对于第三种区间,容易发现每个区间的权值一样,只需要算出个数即可. 对于前两种空间,我的思路是 ...

  3. 牛客CSP-S提高组赛前集训营5 赛后总结

    A.无形的博弈 心理题. 答案为\(2^n\),可感性理解结论的正确性. #include<bits/stdc++.h> #define LL long long const LL Mod ...

  4. 牛客CSP-S提高组赛前集训营2 赛后总结

    比赛链接 A.服务器需求 维护每天需要的服务器数量的全局最大值(记为\(Max\))和总和(记为\(sum\)),那么答案为: \[max(Max,\lceil\dfrac{sum}{m}\rceil ...

  5. 牛客CSP-S提高组赛前集训营1

    牛客CSP-S提高组赛前集训营1 比赛链接 官方题解 before:T1观察+结论题,T2树形Dp,可以换根或up&down,T3正解妙,转化为图上问题.题目质量不错,但数据太水了~. A-仓 ...

  6. 牛客CSP-S提高组赛前集训营3

    A 货物收集 显然是一个二分答案的题. #include<iostream> #include<cstdio> #include<cstring> #include ...

  7. 牛客CSP-S提高组赛前集训营2 ———— 2019.10.31

    比赛链接 期望得分:100+20+20 实际得分:40+20+30 awa  cccc T1 :基于贪心的思路,然后开始爆搜(雾 那必然是会死的,好吧他就是死了 #include<iostrea ...

  8. 牛客CSP-S提高组赛前集训营1———2019.10.29 18:30 至 22:00

    期望得分:100+0+10 实际得分:40+0+0 考炸了... T1:题目链接 究竟为什么会这样,,, 仔细研读我的丑代码 发现... 枯辽.... #include<cstdio> # ...

  9. 牛客CSP-S提高组赛前集训营2 T2沙漠点列

    原题链接 算法不难,比赛的时候就和cyc大佬一起yy了正解,不过因为交的时候比较急(要回寝室惹),我有两数组开错大小直接爆到50,cyc大佬则只把文件输入关了一半,直接爆零(╯ ̄Д ̄)╯┻━┻ 要尽量 ...

随机推荐

  1. Ubuntu切换为阿里镜像源

    前言 在VM虚拟机搭建Ubuntu系统学习或者测试时,常常要使用apt安装测试,但是由于系统自带的下载源在国外服务器上,下载速度慢的无法忍受.所以我们需要切换为国内镜像源,能显著加快安装包下载速度. ...

  2. 正规表达式与有限自动机和LEX

    正规式与有限自动机的等价性 一个正规式r与一个有限自动机M等价, L(r)=L(M) FA ->正规式,对任何FA M,都存在一个正规式r,使得L(r)=L(M). 正规式 -> FA, ...

  3. Windows10访问Ubuntu子系统(WSL)的桌面环境

    原文地址:https://blog.csdn.net/xmh19936688/article/details/90212960 Windows10访问Ubuntu子系统(WSL)的桌面环境文章目录Wi ...

  4. VMware使用与安装

    VMware安装 下载完Vmware -> 双击打开安装包 -> 选择下一步(如下图界面) 选择接受协议,点击下一步 选择经典进行安装.这个是默认安装,会把默认插件安装到相对应的路径 选择 ...

  5. PS切图工具

    缓存设置: 编辑-首选项-暂存盘 改完除了C盘之外的其他盘 单位设置: 编辑-首选项-单位与标尺 将单位修改成像素  PS预设: 工具   (窗口-工具) 标尺  (视图-标尺) 图层  (窗口-图层 ...

  6. Codeforces Round #340 (Div. 2) E XOR and Favorite Number 莫队板子

    #include<bits/stdc++.h> using namespace std; <<; struct node{ int l,r; int id; }q[N]; in ...

  7. css3基础-选择器+边框与圆角+背景与渐变

    Css3选择器相关: section > div直接子元素选择器 div + article相邻兄弟选择器(在元素之后出现) div ~ article通用兄弟选择器(在元素之后出现) 属性选择 ...

  8. linux系统挂载u盘拷贝文件

    linux系统在不能远程的情况下用u盘传文件(比如服务器装上系统还没配IP),需要先将u盘挂载到系统中的某个位置,再使用cp命令拷贝文件,简要步骤如下: 1.把U盘插入Linux电脑,确保U盘指示灯是 ...

  9. 简单java web制作思路

    经过俩天的摸索,和学姐的帮助下终于做出来一个简单地网页版的学生信息添加的系统.接下来说一下答题的思路: 首先我个人习惯先做网页界面,创建3个jsp文件分别是添加界面,成功界面,失败界面.这件看起来更加 ...

  10. 论文阅读笔记(十七)【ICCV2017】:Dynamic Label Graph Matching for Unsupervised Video Re-Identification

    Introduction 文章主要提出了 Dynamic Graph Matching(DGM)方法,以非监督的方式对多个相机的行人视频中识别出正确匹配.错误匹配的结果.本文主要思想如下图: 具体而言 ...