多校A层冲刺NOIP2024模拟赛08 排列
多校A层冲刺NOIP2024模拟赛08 排列
一种连续段 dp 的解法。
题面
小 Y 最近在研究组合数学,他学会了如何枚举排列。
小 Z 最近在研究数论,他学会了求最大公约数。
于是小 Y 和小 Z 联手出了一个有趣的题目:
有多少个长度为 \(n\) 且任意相邻两个数的最大公约数都不为 \(k\) 的排列?
然而他们并不会做这个题,所以请你来帮帮他们吧!
思路
设 \(dp[i][j]\) 为插入了 \(1\sim i\),形成了 \(j\) 个连续段,且合法的情况。
强制让两两间 \(gcd\) 为 \(k\) 的数划分到不同的段,这样在最终的排列中 \(gcd\) 为 \(k\) 的数一定不会相邻。
接着发现只有 \(k\) 的倍数的 \(gcd\) 有可能为 \(k\)。
故把 \(k\) 的倍数进行全排列,在排列的基础上划分段,若在排列中两两间的 \(gcd\) 为 \(k\) 则强制划分为两段,否则可划分可不划分,并将划分成 \(j\) 段的方案数加至 \(dp[0][j]\) 中。
然后之间进行朴素的连续段 dp 即可。
CODE
// ubsan: undefined
// accoders
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define mod 998244353
const int maxn=3005;
int n,k,m;
int p[15],gcd[15][15];
ll dp[maxn][maxn],fac[20],inv[20];
bool vis[15];
inline ll ksm(ll x,ll y)
{
ll sum=1;
for(;y;y/=2,x=x*x%mod) if(y&1) sum=sum*x%mod;
return sum;
}
inline void init()
{
fac[0]=1;
for(int i=1;i<=15;i++) fac[i]=fac[i-1]*i%mod;
inv[15]=ksm(fac[15],mod-2);
for(int i=14;~i;i--) inv[i]=inv[i+1]*(i+1)%mod;
for(int i=1;i<=10;i++) for(int j=1;j<=10;j++) gcd[i][j]=__gcd(i,j);
}
inline ll C(int n,int m)
{
if(n<m) return 0;
return fac[n]*inv[m]%mod*inv[n-m]%mod;
}
inline void dfs(int x)
{
if(x>m)
{
int cnt=0;
for(int i=1;i<m;i++)
if(gcd[p[i]][p[i+1]]==1) cnt++;
for(int i=cnt+1,j=0;i<=m;i++,j++) dp[0][i]=(dp[0][i]+C(m-cnt-1,j))%mod;
return ;
}
for(int i=1;i<=m;i++)
{
if(vis[i]) continue;
vis[i]=true;p[x]=i;
dfs(x+1);
vis[i]=false;p[x]=0;
}
}
int main()
{
freopen("permutation.in","r",stdin);
freopen("permutation.out","w",stdout);
scanf("%d%d",&n,&k);
init();
m=n/k;
dfs(1);
for(int i=1;i<=n;i++)
{
if(i%k==0)
{
for(int j=1;j<=n;j++) dp[i][j]=dp[i-1][j];
}
else
{
for(int j=1;j<=n;j++)
{
dp[i][j]=dp[i-1][j+1]*j%mod+dp[i-1][j]*2*j%mod+dp[i-1][j-1]*j%mod;
dp[i][j]%=mod;
}
}
}
printf("%lld",dp[n][1]);
}
多校A层冲刺NOIP2024模拟赛08 排列的更多相关文章
- 多校B层冲刺NOIP20211111模拟12
题面:PDFhttp://xn--gwt928b.accoders.com/pdf/10248/10248.pdfhttp://xn--gwt928b.accoders.com/pdf/10248/1 ...
- 【CJOJ P1957】【NOIP2010冲刺十模拟赛】数字积木
[NOIP2010冲刺十模拟赛]数字积木 Description 小明有一款新式积木,每个积木上都有一个数,一天小明突发奇想,要是把所有的积木排成一排,所形成的数目最大是多少呢? 你的任务就是读入n个 ...
- 冲刺Noip2017模拟赛7 解题报告——五十岚芒果酱
1.二叉树(binary) .二叉树 (binary.cpp/c/pas) [问题描述] 二叉排序树或者是一棵空树,或者是具有下列性质的二叉树: ()若左子树不空,则左子树上所有结点的值均小于它的根结 ...
- 冲刺Noip2017模拟赛8 解题报告——五十岚芒果酱
1.鼎纹 [问题描述] 据说鼎纹的 种制造 式是 铜模印出来的,这是我国古代劳动 智慧 的结晶.铜模印过的地 ,会留下深深的印记,经过时间的炼化,洗 练成历史的遗存. 聪明的古代劳动人民拥有一个 a ...
- 冲刺Noip2017模拟赛4 解题报告——五十岚芒果酱
题1 韬韬抢苹果(apple) [问题描述] 又到了收获的季节,树上结了许多韬韬,错了,是许多苹果,有很多个小韬韬都来摘苹 果.每个韬韬都想要最大的苹果,所以发生了争执,为了解决他们的矛盾,出题人定了 ...
- 冲刺Noip2017模拟赛2 解题报告——五十岚芒果酱
题1 牛跑步(running) [题目描述] 新牛到部队,CG 要求它们每天早上搞晨跑,从 A 农场跑到 B 农场.从 A 农场到 B 农场中有 n- 个路口,分别标上号,A 农场为 号,B 农场为 ...
- 冲刺Noip2017模拟赛1 解题报告——五十岚芒果酱
题1 国际象棋(chess) [问题描述] 有N个人要参加国际象棋比赛,该比赛要进行K场对弈.每个人最多参加2场对弈,最少参加0场对弈.每个人都有一个与其他人都不相同的等级(用一个正整数来表示).在对 ...
- 冲刺Noip2017模拟赛6 解题报告——五十岚芒果酱
1.ksum(ksum) [问题描述] Peter喜欢玩数组.NOIP这天,他从Jason手里得到了大小为n的一个正整数 数组. Peter求出了这个数组的所有子段和,并将这n(n+)/2个数降序排序 ...
- 冲刺Noip2017模拟赛5 解题报告——五十岚芒果酱
1. 公约数(gcd) [问题描述] 给定一个正整数,在[,n]的范围内,求出有多少个无序数对(a,b)满足 gcd(a,b)=a xor b. [输入格式] 输入共一行,一个正整数n. [输出格式] ...
- 冲刺Noip2017模拟赛3 解题报告——五十岚芒果酱
题1 素数 [问题描述] 给定一个正整数N,询问1到N中有多少个素数. [输入格式]primenum.in 一个正整数N. [输出格式]primenum.out 一个数Ans,表示1到N中有多少个素 ...
随机推荐
- YuebonCore:基于.NET8开源、免费的权限管理及快速开发框架
前言 今天大姚给大家分享一款基于.NET8开源.免费(MIT License)功能强大的权限管理及快速开发框架,支持前后端分离,项目架构易于扩展,是中小企业的首选:YuebonNetCore. 核心设 ...
- JSP中的JSTL 标签库
目录 JSTL 标签库 JSTL 标签库的使用步骤 core 核心库使用 <c:set /> (使用很少) <c:if /> <c:choose><c:whe ...
- 【YashanDB知识库】表收集统计信息默认阈值引起SQL执行效率差
[问题分类]性能优化 [关键字]统计信息,阈值,执行计划 [问题描述]表新增87w数据自动收集统计信息任务没有启动导致SQL执行计划变差 [问题原因分析] CUS_REGISTER_READ 数据总量 ...
- 立体视觉 StereoVision
双目相机 原理 [深度相机系列三]深度相机原理揭秘--双目立体视觉 StereoVision--立体视觉(1) StereoVision--立体视觉(2) StereoVision--立体视觉(3) ...
- 鸿蒙应用开发:环境搭建(Mac)与项目构建
2021年6月2日,华为发布了鸿蒙操作系统-HarmonyOS.它是一款"面向未来".面向全场景(移动办公.运动健康.社交通信.媒体娱乐等)的分布式操作系统.我们要基于Harm ...
- [rCore学习笔记 026]第三章作业
写在前面 本随笔是非常菜的菜鸡写的.如有问题请及时提出. 可以联系:1160712160@qq.com GitHhub:https://github.com/WindDevil (目前啥也没有 编程题 ...
- Redis 内存突增时,如何定量分析其内存使用情况
背景 最近碰到一个 case,一个 Redis 实例的内存突增,used_memory最大时达到了 78.9G,而该实例的maxmemory配置却只有 16G,最终导致实例中的数据被大量驱逐. 以下是 ...
- 使用 fabric.js 开发移动端 H5 图片编辑器
大家好,我是开源图片编辑器的 https://github.com/ikuaitu/vue-fabric-editor 的作者,它是一款基于 PC 版本的开源图片编辑器. 最近很多开发者咨询,是否可以 ...
- oneforall配置环境,报错cannot import name 'sre_parse' from 're' 解决方法
高版本python中re模块没有了sre_parse模块, 可以修改python中的exrex.py 代码,直接导入sre_parse模块
- foobar2000 v2.1.5 汉化版(更新日期:2024.09.08)
foobar2000 v2.1.5 汉化版 -----------------------[软件截图]---------------------- -----------------------[软件 ...