NOIP 模拟八 考试总结
T1星际旅行
给出n个点,m条边,求满足一条路径使得m-2条边经过2次,2条边经过1次的方案数.并且题目中给出有自环.
看到题面我以为是个计数DP,可能是计数题做多了吧哈哈.其实仔细朝图的方向想一想就会发现,把每条边double一下,题目的要求就是去掉两条边,然后还能是欧拉路一笔画走完.
欧拉路的性质就是点的度数为偶,或者是其中两点度数为奇数.所以就要考虑拆边怎莫拆.
因为我把路径double了一下,所以现在度数都是偶数,如果随便拆两条边,那么肯定会出现四个单点,所以我拆的两条边要有公共点.在来看自环,很明显自环对奇偶是毫无影响的,所以可以是任意一个自环和一个边,或者是任意两个自环.
以上三种加起来便是方案书.注意要判不联通的情况,而且因为题目是在边上做文章,所以点联不联通是无所谓的,我只需判边,用并查集即可.
code
#include<bits/stdc++.h>
#define int long long
using namespace std;
int n,m,ji,head[300001],in[300001],fa[300001],cnt,sum[300001],ans;
struct AYX
{int to,next;}bian[600001];
inline int find(int x)
{ if(x!=fa[x])return fa[x]=find(fa[x]);
return x;
}
inline void add(int u,int v)
{ bian[++ji].next=head[u];
bian[ji].to=v;
head[u]=ji;
}
signed main()
{ scanf("%lld%lld",&n,&m);
for(int i=1;i<=n;++i)fa[i]=i;
for(int i=1;i<=m;++i)
{ int a,b;
scanf("%lld%lld",&a,&b);
if(a==b)++cnt,++sum[a],++sum[b];
else {++in[a],++in[b];fa[find(a)]=find(b);}
add(a,b);add(b,a);
}
int ww=0;
for(int i=1;i<=n;++i)
for(int j=head[i];j;j=bian[j].next)
{ int v=bian[j].to;
if(!ww){ww=find(v);continue;}
if(ww!=find(v))
{ printf("0\n");
return 0;
}
}
for(int i=1;i<=n;++i)ans+=(in[i]-1)*in[i]/2;
ans+=cnt*(cnt-1)/2;
ans+=cnt*(m-cnt);
printf("%lld\n",ans);
}
T2砍树
式子不好搞,额,不是不好推,是不好打...........
maxd 要满足floor(a[i]/d)*d-a[i]<=k;
转化一下得到floor(a[i]/d)<=(k+a[i])/d;
k+a[i]为定值,设为T;则floor(a[i]/d)<=T/d;
明显是数论分块,检查每一个右端点取max就好,因为只有100个数,check时暴力算就行.
复杂度T^(1/2)*n;
code
#include<bits/stdc++.h>
#define int long long
using namespace std;
int n,a[3000001],k,T,ans;
inline bool check(int x)
{ int d=T/x,sum=0;
for(int i=1;i<=n;++i)
{ if(a[i]%x==0)sum+=a[i]/x;
else sum+=a[i]/x+1;
}
return sum<=d;
}
inline void work()
{ for(int l=1,r;l<=T;l=r+1)
{ r=T/(T/l);
if(check(r))ans=max(ans,r);
}
printf("%lld\n",ans);
}
signed main()
{ scanf("%lld%lld",&n,&k);
for(int i=1;i<=n;++i)scanf("%lld",&a[i]),T+=a[i];
T+=k;
work();
}
T3超级树
这个计数dp不好搞,这是真不好搞.
f[i][j]表示第i个,有j条点不重复的路径.
设num=f[i-1][l]*f[i-1][r];
f[i][l+r]+=num;这是对这棵树神魔也不做.
f[i][l+r+1]+=num;这是将跟节点作为一条新路径.
f[i][l+r]+=num(l+r)2;这是将根连到左右子树的某个路径上.
f[i][l+r-1]+=num* l* r *2;这是将根与左右各一条相连.
f[i][l+r-1]+=num(l(l-1)+r*(r-1));这是根与同一子树中两条路径相连.
因为最终对ans有贡献的只有k个状态,所以第二维只有k.
code
#include<bits/stdc++.h>
#define re register
using namespace std;
int k,mod;
long long f[3001][3001];
signed main()
{ scanf("%d%d",&k,&mod);
f[1][0]=f[1][1]=1;
for(re int i=2;i<=k;++i)
for(re int j=0;j<=k;++j)
for(re int r=0;r<=j;++r)
{ int l=j-r;
long long sum=f[i-1][l]*f[i-1][r]%mod;
f[i][l+r]=(f[i][l+r]+sum)%mod;
f[i][l+r+1]=(f[i][l+r+1]+sum)%mod;
f[i][l+r]=(f[i][l+r]+sum*2*(l+r))%mod;
f[i][l+r-1]=(f[i][l+r-1]+2*sum*l*r)%mod;
f[i][l+r-1]=(f[i][l+r-1]+sum*(l*(l-1)+r*(r-1)))%mod;
}
printf("%lld\n",f[k][1]%mod);
}
T4求和
数据超水,暴力都能撵过去,可惜我没mod,100-->0..............
正解也够暴力的,就是预处理每个dep的1-50次方,和其前缀和.询问时求lca,O(1)搞出ans;
code就借WTZ一用,也算有咱一半产权吧.
#include<bits/stdc++.h>
#define mod 998244353
#define int long long
using namespace std;
inline int read(){
int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-') f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<1)+(x<<3)+(ch^48);ch=getchar();}
return x*f;
}
inline void write(int x){
if(x<0) x=-x,putchar('-');
if(x>10) write(x/10);
putchar(x%10+'0');
}
int n,m,ans;
int siz[300010],fa[300010],son[300010],top[300010],dep[300010],mxd=0;
int depk[300010][51],sum[300010][51];
int head[300010],ver[600010],to[600010],tot;
inline void add(int x,int y){
ver[++tot]=y;
to[tot]=head[x];
head[x]=tot;
}
inline void dfs1(int x,int fath,int depth){
int maxson=-1;
fa[x]=fath,dep[x]=depth,siz[x]=1;mxd=max(mxd,depth);
for(int i=head[x];i;i=to[i]){
int y=ver[i];
if(y==fath) continue;
dfs1(y,x,depth+1);
siz[x]+=siz[y];
if(siz[y]>maxson) son[x]=y,maxson=siz[y];
}
}
inline void dfs2(int x,int topf){
top[x]=topf;
if(!son[x]) return;
dfs2(son[x],topf);
for(int i=head[x];i;i=to[i]){
int y=ver[i];
if(y==fa[x]||y==son[x]) continue;
dfs2(y,y);
}
}
inline int LCA(int x,int y){
while(top[x]!=top[y]){
if(dep[top[x]]<dep[top[y]]) swap(x,y);
x=fa[top[x]];
}
if(dep[x]>dep[y]) swap(x,y);
return x;
}
signed main(){
n=read();
for(int i=1,x,y;i<n;i++){
x=read(),y=read();
add(x,y),add(y,x);
}
dfs1(1,0,0);dfs2(1,1);
for(int i=1;i<=mxd;i++){
depk[i][1]=i;
for(int j=2;j<=50;j++) depk[i][j]=depk[i][j-1]*i%mod;
}
for(int i=1;i<=mxd;i++) for(int j=1;j<=50;j++) sum[i][j]=(sum[i-1][j]+depk[i][j])%mod;
m=read();
for(int i=1,x,y,k,lca;i<=m;i++){
x=read(),y=read(),k=read();
lca=LCA(x,y);
ans=0;
ans=(sum[dep[x]][k]-sum[dep[lca]][k]+mod)%mod+(sum[dep[y]][k]-sum[dep[fa[lca]]][k]+mod)%mod;
printf("%lld\n",ans%mod);
}
return 0;
}
NOIP 模拟八 考试总结的更多相关文章
- 【noip模拟】考试总结
今天睡了14个小时啊 把一星期的觉都补回来了 要不是被叫醒了 我肯定还在睡觉- - 其实现在还想睡... 集训真是伤身啊 感觉再睡就要睡成sb了 鉴于昨天被完虐(真·完虐 怒垫底) 来写篇总结 得分: ...
- NOIP 模拟 6 考试总结
T1 这道题是一道裸的暴力,考场写挂了 \(5pts\) 原因竟是忘了删注释,难受 题解 T2 这道题是一道启发式合并,没想出来,拿了个暴力分跑了 题解 T3 这道题就是一道数学期望,想出来就水得很, ...
- NOIP 模拟九 考试总结
T1 考场上先干的T2,最后慌慌张张没去想正解,打算把树建起来,拿70分的部分分,于是写树剖LCA,板子好像忘了,回忆了好久还模拟了好几遍才打对树剖LCA............期望70,结果0.考试 ...
- NOIP 模拟 10 考试总结
T1 一道很妙的题,打暴力分也很多,但是考试的时候忘开 long long 了. 题解 T2 一道挺水的题,不过...(打挂了) 题解 T3 此题甚妙,转化真多,不过对思维是一个非常大的扩展 题解 考 ...
- NOIP 模拟六 考试总结
T1辣鸡 T1就搞得这莫不愉快.. 大致题意是给你几个矩形,矩形覆盖的点都标记上,每个矩形无重复部分,求满足(x,y) (x+1,y+1)都标记过的点对数,范围1e9. 看起来很牛的样子,我确实也被1 ...
- NOIP 模拟一 考试总结
序列 考场上信心满满的打了nlogn的做法,我以为我稳了.据考试结束1h时发现看错题目了,打成了不连续的子序列.匆匆改了n2logn的做法.考试结束后,我发现我跪了.原来到终点才会发现我做的和人家不是 ...
- NOIP 模拟 八十五
T1 冲刺NOIP2021模拟18 莓良心 容易发现答案和每一个 \(w_i\) 无关,我们只需要求出总和然后计算方案数. 对于每一个数贡献的方案数是相同的,首先是自己的部分就是\(\begin{Bm ...
- 2016.11.6 night NOIP模拟赛 考试整理
题目+数据:链接:http://pan.baidu.com/s/1hssN8GG 密码:bjw8总结: 总分:300分,仅仅拿了120份. 这次所犯的失误:对于2,3题目,我刚刚看就想到了正确思路,急 ...
- NOIP 模拟 7 考试总结
T1 超级大水题,用 \(kmp\) 和 \(hash\) 均能过,但都忘了,结果只打了个暴力.难受.板子题,题解就不放了 Code #include<bits/stdc++.h> #de ...
随机推荐
- Hibernate脑图
- JavaWeb之HttpSession
时间:2016-11-17 22:33 --HttpSession一.HttpSession概述 1.HttpSession是由JavaWeb提供的,用来进行会话跟踪的类. 2.sessi ...
- spring boot应用常用配置
pom.xml <!--自动打包--> <plugin> <groupId>org.springframework.boot</groupId> < ...
- 有关spring注解总结
前言 目前企业开发多采用纯注解的方式开发,注解开发的好处:简洁,可读性强 最近学习了spring全家桶,总结了有关spring的常用注解,写的不对的地方,欢迎指正 Spring模块注解 @Config ...
- go语言内存对齐
内存对齐 为保证程序顺利高效的运行,编译器会把各种类型的数据安排到合适的地址并占用合适的长度,这就是内存对齐 每种类型的对齐值就是他的内存边界 64位 类型 对齐边界 (对齐值) int8 1byte ...
- ASP.NET真分页_接前篇引用AspNetPager.dll进行数据分页
一.前端准备工作 1.之前我写到过<Asp.net中引用AspNetPager.dll进行数据分页> 这种分页方式只能在前台将数据分页,而每次点击查询时对目标数据库还是全查询,这样不仅会 ...
- .NetCore3.1获取文件并重新命名以及大批量更新及写入数据
using Microsoft.AspNetCore.Mvc; using MySql.Data.MySqlClient; using System; using System.Collections ...
- C# 简单粗暴的毫秒转换成 分秒的格式
C# 简单粗暴的毫秒转换成 分秒的格式 1:code(网络上很多存在拷贝或者存在bug的或者不满足自己的要求) 1 public static string RevertToTime(double m ...
- Springboot自带定时任务实现动态配置Cron参数
同学们,我今天分享一下SpringBoot动态配置Cron参数.场景是这样子的:后台管理界面对定时任务进行管理,可动态修改执行时间,然后保存入库,每次任务执行前从库里查询时间,以达到动态修改Cron参 ...
- vue ele 日期时间格式限制不能早于当天,时间转换成时间戳 进行比较
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model=&quo ...