人的记忆本来就是暧昧的,不值得信任。

前言

又是令人头疼的数学部分。。还是太菜了。。

晚上还有一场,当场裂开。

T1 工业题

解题思路

首先,这个题的暴力还是非常好像的,直接按照题目要求码就好了。

对于正解,主要思路是计算每一个 \(f(i,0)\) 和 \(f(0,i)\) 对于答案的贡献。

其实就像从某个点(假设是 \((i,j)\) )向 \((n,m)\) 走,并且仅能向右向上走。

显然,贡献就是 \(a^{m-j}\times b^{n-i}\times f(i,j)\times 方案数\)。

接下来的问题就是求方案数了,那么一共有 \(n+m-i-j\) 步,它们无论如何排列的结果都是一样的。

由于向上走一步其实是相同的操作,但是我们按照他们不同来算了,因此需要除去一些的排列,就是:

\[\dfrac{A_{n+m-i-j}^{n+m-i-j}}{A_{n-i}^{n-i}\times A_{m-j}^{m-j}}
\]

算出来就是:

\[\dfrac{(n+m-i-j)!}{(n-i)!\times (m-j)!}
\]

阶乘以及 a,b 的幂次方都是可以预处理出来的,至于除法直接逆元就好了。

注意,这里有个魔鬼细节:

在 0 行 0 列之间是无法转移下去的,但是 1 行 1 列是可以的,并且差距仅仅是行列数之间的差距,因此只需要一些 +1 和 -1 就好了。

另外,注意一下取 \(\bmod\) 。

code

#include<bits/stdc++.h>
#define int long long
using namespace std;
inline int read()
{
int x=0,f=1;
char ch=getchar();
while(ch>'9'||ch<'0')
{
if(ch=='-') f=-1;
ch=getchar();
}
while(ch>='0'&&ch<='9')
{
x=(x<<1)+(x<<3)+(ch^48);
ch=getchar();
}
return x*f;
}
const int N=3e5+10,mod=998244353;
int n,m,a,b,ans,jc[N<<1],s1[N],s2[N],af[N],bf[N];
void Jc_Init()
{
jc[0]=af[0]=bf[0]=1;
for(int i=1;i<=m+n;i++)
jc[i]=jc[i-1]*i%mod;
for(int i=1;i<=m;i++)
af[i]=af[i-1]*a%mod;
for(int i=1;i<=n;i++)
bf[i]=bf[i-1]*b%mod;
}
int ksm(int x,int y)
{
int sum=1;
while(y)
{
if(y&1) sum=sum*x%mod;
y>>=1;
x=x*x%mod;
}
return sum;
}
signed main()
{
n=read();
m=read();
a=read()%mod;
b=read()%mod;
for(int i=1;i<=n;i++)
s1[i]=read()%mod;
for(int i=1;i<=m;i++)
s2[i]=read()%mod;
Jc_Init();
for(int i=1;i<=n;i++)
ans=(ans+jc[n+m-i-1]*ksm(jc[m-1],mod-2)%mod*ksm(jc[n-i],mod-2)%mod*bf[n-i]%mod*af[m]%mod*s1[i]%mod)%mod;
for(int i=1;i<=m;i++)
ans=(ans+jc[n+m-i-1]*ksm(jc[m-i],mod-2)%mod*ksm(jc[n-1],mod-2)%mod*af[m-i]%mod*bf[n]%mod*s2[i]%mod)%mod;
printf("%lld",ans);
return 0;
}

T2 卡常题

解题思路

不难发现因为每一个 Y 方点都只有两条边,因此可以将 Y 方点当作边, X 方点当作点。

我们就得到了一个有 n 条边, n 个点的环套树,显然,它比一般的树多了一条边,怎么办呢???

直接拆掉就好了,就是直接拆掉。

又因为每一个 X 方点是可以间隔存在的,剩下的就类似于 没有上司的舞会 这道题了。

在两个断点处进行两边树形 DP 取最小值就好了。

树形 DP 时分别记录一下选与不选这个点的值就好了。

code

#include<bits/stdc++.h>
#define int long long
#define f() cout<<"Fuck"<<endl;
using namespace std;
inline int read()
{
int x=0,f=1;
char ch=getchar();
while(ch>'9'||ch<'0')
{
if(ch=='-') f=-1;
ch=getchar();
}
while(ch>='0'&&ch<='9')
{
x=(x<<1)+(x<<3)+(ch^48);
ch=getchar();
}
return x*f;
}
const int N=1e6+10;
int tot,head[N],ver[N<<1],nxt[N<<1];
int n,vh,vb,bk1,bk2,ans,h[N],b[N],val[N],f[N][2];
bool vis[N];
void add_edge(int x,int y)
{
ver[++tot]=y;
nxt[tot]=head[x];
head[x]=tot;
}
void dfs(int x,int fro)
{
if(vis[x])
{
bk1=x;
bk2=fro;
return ;
}
if(bk1||bk2) return ;
vis[x]=true;
for(int i=head[x];i;i=nxt[i])
if(ver[i]!=fro)
dfs(ver[i],x);
}
void solve(int x,int fro)
{
f[x][1]=val[x];
f[x][0]=0;
for(int i=head[x];i;i=nxt[i])
if(ver[i]!=fro&&!(ver[i]==bk1&&x==bk2)&&!(ver[i]==bk2&&x==bk1))
{
int to=ver[i];
solve(to,x);
f[x][1]+=min(f[to][0],f[to][1]);
f[x][0]+=f[to][1];
}
}
signed main()
{
n=read();
vh=read();
vb=read();
for(int i=1;i<=n;i++)
{
h[i]=read();
b[i]=read();
val[h[i]]+=vh;
val[b[i]]+=vb;
add_edge(h[i],b[i]);
add_edge(b[i],h[i]);
}
dfs(1,0);
solve(bk1,bk2);
ans=f[bk1][1];
solve(bk2,bk1);
ans=min(ans,f[bk2][1]);
printf("%lld",ans);
return 0;
}

T3 玄学题

解题思路

-1 的次幂是由 \(d(i\times j)\) 的个数决定的。

-1 的偶数次幂是 1 对于答案是没有影响的,因此我们只用考虑 \(d(i\times j)\) 为奇数的时候。

当且仅当 \(i\times j\) 是完全平方数的时候 \(d(i\times j)\) 的值才是奇数。

原因比较显然:约数就是二个数的积等于这个数;对于非平方数的数每一约数都有一个对应的约数。

接下来把 i 拆成 \(p\times q^2\)( p 没有平方因子)对于 j 一定有 \(p\times r^2\) 的形式。

因此,对于每一个符合条件的 j 就有 r 种取值也就是 \(\sqrt{\dfrac{m}{p}}\) 。

显然的,我们可以通过筛出所有的完全平方数进而求出 p 的值(求的过程类似于欧拉筛筛素数)。

code

#include<bits/stdc++.h>
#define int long long
#define f() cout<<"Fuck"<<endl;
using namespace std;
inline int read()
{
int x=0,f=1;
char ch=getchar();
while(ch>'9'||ch<'0')
{
if(ch=='-') f=-1;
ch=getchar();
}
while(ch>='0'&&ch<='9')
{
x=(x<<1)+(x<<3)+(ch^48);
ch=getchar();
}
return x*f;
}
const int N=1e7+10;
int n,m,ans,cnt,f[N],pri[N];
bool vis[N];
signed main()
{
n=read();
m=read();
vis[1]=true;
pri[++cnt]=1;
for(int i=2;i<=n;i++)
{
if(vis[i]) pri[++cnt]=i;
int temp=i*i;
for(int j=1;j<=cnt&&pri[j]*temp<=n;j++)
vis[pri[j]*temp]=true;
}
for(int i=1;i<=n;i++)
{
if(!vis[i]) continue;
for(int j=1;j*i<=n;j++)
if(!vis[j])
f[j*i]=j;
}
for(int i=1;i<=n;i++)
{
if(!f[i]) f[i]=1;
int temp=sqrt(m/f[i]);
if(temp&1) ans--;
else ans++;
}
printf("%lld",ans);
return 0;
}

7.13早考试总结(NOIP模拟13)[工业题·卡常题·玄学题]的更多相关文章

  1. HZOI20190906模拟39 工业,卡常,玄学

    题面:https://www.cnblogs.com/Juve/articles/11484209.html 工业: 推一个式子,AC 没有用组合数....推了2个多小时 我sbsbsbsbsbsbs ...

  2. [考试总结]noip模拟13

    因为最近考试频繁,所以咕掉了好长时间... 淦,刚说完又来一场... 先咕了,等以后有时间再写.... 回来了... 首先看到这个题目们,感觉就不存好意... 然后开始开 \(T1\). 只能蒻蒻地按 ...

  3. 5.23考试总结(NOIP模拟2)

    5.23考试总结(NOIP模拟2) 洛谷题单 看第一题第一眼,不好打呀;看第一题样例又一眼,诶,我直接一手小阶乘走人 然后就急忙去干T2T3了 后来考完一看,只有\(T1\)骗到了\(15pts\)[ ...

  4. 6.17考试总结(NOIP模拟8)[星际旅行·砍树·超级树·求和]

    6.17考试总结(NOIP模拟8) 背景 考得不咋样,有一个非常遗憾的地方:最后一题少取膜了,\(100pts->40pts\),改了这么多年的错还是头一回看见以下的情景... T1星际旅行 前 ...

  5. 5.22考试总结(NOIP模拟1)

    5.22考试总结(NOIP模拟1) 改题记录 T1 序列 题解 暴力思路很好想,分数也很好想\(QAQ\) (反正我只拿了5pts) 正解的话: 先用欧拉筛把1-n的素数筛出来 void get_Pr ...

  6. noip模拟12[简单的区间·简单的玄学·简单的填数]

    noip模拟12 solutions 这次考试靠的还是比较好的,但是还是有不好的地方, 为啥嘞??因为我觉得我排列组合好像白学了诶,文化课都忘记了 正难则反!!!!!!!! 害没关系啦,一共拿到了\( ...

  7. Noip模拟13 2021.7.13:再刚题,就剁手&&生日祭

    T1 工业题 这波行列看反就非常尴尬.....口糊出所有正解想到的唯独行列看反全盘炸列(因为和T1斗智斗勇两个半小时...) 这题就是肯定是个O(n+m)的,那就往哪里想,a,b和前面的系数分开求,前 ...

  8. 2021.9.17考试总结[NOIP模拟55]

    有的考试表面上自称NOIP模拟,背地里却是绍兴一中NOI模拟 吓得我直接文件打错 T1 Skip 设状态$f_i$为最后一次选$i$在$i$时的最优解.有$f_i=max_{j<i}[f_j+a ...

  9. [考试总结]noip模拟23

    因为考试过多,所以学校的博客就暂时咕掉了,放到家里来写 不过话说,vscode的markdown编辑器还是真的很好用 先把 \(noip\) 模拟 \(23\) 的总结写了吧.. 俗话说:" ...

  10. NOIP模拟测试39,思维禁锢专场「工业题·玄学题·卡常题」

    工业题 题解 抱歉,题解没时间写了 代码 #include<bits/stdc++.h> using namespace std; #define ll long long #define ...

随机推荐

  1. button submit你以为你阻止了默认事件?

    前言 先解决掉一个误区: 很多人写button的时候,就这样写: <button><botton> 你认为就是默认的submit的时候,这时候就可能出问题了. 当然之所以你没有 ...

  2. 吴恩达机器学习课后作业ex1

    题目大体意思就是输入的是某地的人口,输出的是某地方的收益. 题目及数据集下载: https://wwa.lanzous.com/b054sprza 密码:ba3w 大体模型如下图:现在X前边加一列值为 ...

  3. KubeOperator技术方案

    KubeOperator技术方案 总体介绍︎ KubeOperator 是一个开源的轻量级 Kubernetes 发行版,专注于帮助企业规划.部署和运营生产级别的 Kubernetes 集群. Kub ...

  4. 基础 IO (Linux学习笔记)

    基础IO 1.重谈文件 空文件在磁盘也要占据空间 文件 = 内容 + 属性 文件操作 = 对文件内容+对属性 or 对文件内容加属性 标定一个文件,必须使用文件路径加文件名[唯一性] 如果没有指明对应 ...

  5. 力扣614(MySQL)-二级关注者(中等)

    题目: 在 facebook 中,表 follow 会有 2 个字段: followee, follower ,分别表示被关注者和关注者. 请写一个 sql 查询语句,对每一个关注者,查询关注他的关注 ...

  6. HarmonyOS NEXT应用开发之预加载so并读取RawFile文件

    介绍 本示例主要介绍在TaskPool子线程中使用 dlopen 预加载 so 库并使用句柄调用库函数的方法,以及在Native中使用 pread 系统函数读取Rawfile文件的部分文本内容,并添加 ...

  7. Serverless在游戏运营行业进行数据采集分析的最佳实践

    简介: 这个架构不光适用于游戏运营行业,其实任何大数据采集传输的场景都是适用的,目前也已经有很多客户正在基于Serverless的架构跑在生产环境,或者正走在改造Serverless 架构的路上. 众 ...

  8. 技术实践第三期|HashTag在Redis集群环境下的使用

    ​简介:欢迎了解友盟+技术干货第三期内容:Redis集群环境如何按照前缀批量删除缓存.希望能对开发者们在实际应用中有所帮助. 一.背景 数据源列表添加缓存支持,types字段可传多值,如app, mi ...

  9. Yurt-Tunnel 详解|如何解决 K8s 在云边协同下的运维监控挑战

    简介: 伴随着 5G.IoT 等技术的快速发展,边缘计算被越来越广泛地应用于电信.媒体.运输.物流.农业.零售等行业和场景中,成为解决这些领域数据传输效率的关键方式.与此同时,边缘计算形态.规模.复杂 ...

  10. 庖丁解牛-图解MySQL 8.0优化器查询解析篇

    ​简介: SQL优化器本质上是一种高度抽象化的数据接口的实现,经过该设计,客户可以使用更通用且易于理解的SQL语言,对数据进行操作和处理,而不需要关注和抽象自己的数据接口,极大地解放了客户的应用程序. ...