多校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中有多少个素 ...
随机推荐
- Ubuntu16.04换成清华大学源
第一:备份源文件 # 源文件sources.list 在/etc/apt/目录下 # 备份源文件 sudo cp sources.list sources.list.bak 第二步:替换源文件 # 清 ...
- SQLserver 数据库自定义函数
起源 最近项目开发上使用的SQLserver数据库是2008版本,由于08版本的数据是没有字符串合并(STRING_AGG)这个函数(2017版本及以上支持)的,只有用stuff +for xml p ...
- 【Git】之分支合并命令
一.Git分支管理 1.查看Git分支 git branch 按Q键返回. 2.创建分支以及删除分支 git branch newtest git branch -d newtest 3.切换分支 g ...
- WKCTF RE
WKCTF so_easy 安卓逆向,关键的check逻辑都在native层里面 主要是很多层的异或操作 除了Z3和爆破想不到其他方法了 from z3 import * src = [ 0xAE, ...
- Feign 动态设定服务器名称 与 调用接口
1. 新增编码器(由于使用了动态的Feign,所以不能像正常使用Feign一样指定configuration配置编码器) import feign.RequestTemplate; import fe ...
- Postman Code Java-Unirest 代码的依赖
本来是Postman的Code直接使用的,结果根据这个名字 Unirest,搜出来了很多依赖,使用了排名第一的, https://search.maven.org/search?q=Unirest 结 ...
- 学习笔记:robots.txt文件
1.1 介绍 robots.txt文件是一种用于指导搜索引擎爬虫在网站上哪些页面可以被抓取,哪些页面不应该被抓取的文本文件.这个文件通常放置在网站的根目录下. 1.2 由来 robots.txt标准最 ...
- git 乱操作
https://www.cnblogs.com/qybk/p/10880901.html 错误提示一样,只是我是在我自己的分支(xxx_dev)里.所以以下要改一下. git pull origin ...
- 全网最适合入门的面向对象编程教程:50 Python函数方法与接口-接口和抽象基类
全网最适合入门的面向对象编程教程:50 Python 函数方法与接口-接口和抽象基类 摘要: 在 Python 中,接口和抽象基类(Abstract Base Classes, ABCs)都用于定义类 ...
- Filter——过滤器
Filter Filter 快速入门 Filter 执行流程 1.放行前,对 request 数据进行处理 2.放行后,对 response 数据进行处理 ...