多校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 排列的更多相关文章

  1. 多校B层冲刺NOIP20211111模拟12

    题面:PDFhttp://xn--gwt928b.accoders.com/pdf/10248/10248.pdfhttp://xn--gwt928b.accoders.com/pdf/10248/1 ...

  2. 【CJOJ P1957】【NOIP2010冲刺十模拟赛】数字积木

    [NOIP2010冲刺十模拟赛]数字积木 Description 小明有一款新式积木,每个积木上都有一个数,一天小明突发奇想,要是把所有的积木排成一排,所形成的数目最大是多少呢? 你的任务就是读入n个 ...

  3. 冲刺Noip2017模拟赛7 解题报告——五十岚芒果酱

    1.二叉树(binary) .二叉树 (binary.cpp/c/pas) [问题描述] 二叉排序树或者是一棵空树,或者是具有下列性质的二叉树: ()若左子树不空,则左子树上所有结点的值均小于它的根结 ...

  4. 冲刺Noip2017模拟赛8 解题报告——五十岚芒果酱

    1.鼎纹 [问题描述] 据说鼎纹的 种制造 式是 铜模印出来的,这是我国古代劳动 智慧 的结晶.铜模印过的地 ,会留下深深的印记,经过时间的炼化,洗 练成历史的遗存. 聪明的古代劳动人民拥有一个 a ...

  5. 冲刺Noip2017模拟赛4 解题报告——五十岚芒果酱

    题1 韬韬抢苹果(apple) [问题描述] 又到了收获的季节,树上结了许多韬韬,错了,是许多苹果,有很多个小韬韬都来摘苹 果.每个韬韬都想要最大的苹果,所以发生了争执,为了解决他们的矛盾,出题人定了 ...

  6. 冲刺Noip2017模拟赛2 解题报告——五十岚芒果酱

    题1 牛跑步(running) [题目描述] 新牛到部队,CG 要求它们每天早上搞晨跑,从 A 农场跑到 B 农场.从 A 农场到 B 农场中有 n- 个路口,分别标上号,A 农场为 号,B 农场为 ...

  7. 冲刺Noip2017模拟赛1 解题报告——五十岚芒果酱

    题1 国际象棋(chess) [问题描述] 有N个人要参加国际象棋比赛,该比赛要进行K场对弈.每个人最多参加2场对弈,最少参加0场对弈.每个人都有一个与其他人都不相同的等级(用一个正整数来表示).在对 ...

  8. 冲刺Noip2017模拟赛6 解题报告——五十岚芒果酱

    1.ksum(ksum) [问题描述] Peter喜欢玩数组.NOIP这天,他从Jason手里得到了大小为n的一个正整数 数组. Peter求出了这个数组的所有子段和,并将这n(n+)/2个数降序排序 ...

  9. 冲刺Noip2017模拟赛5 解题报告——五十岚芒果酱

    1. 公约数(gcd) [问题描述] 给定一个正整数,在[,n]的范围内,求出有多少个无序数对(a,b)满足 gcd(a,b)=a xor b. [输入格式] 输入共一行,一个正整数n. [输出格式] ...

  10. 冲刺Noip2017模拟赛3 解题报告——五十岚芒果酱

    题1  素数 [问题描述] 给定一个正整数N,询问1到N中有多少个素数. [输入格式]primenum.in 一个正整数N. [输出格式]primenum.out 一个数Ans,表示1到N中有多少个素 ...

随机推荐

  1. vscode使用说明

    # 要经常保存 # centos打开vscode方式 普通用户:[bw@localhost ~]$ /usr/share/code/bin/code 超级用户:[root@localhost shar ...

  2. SpringBoot多环境日志配置

    SpringBoot多环境日志配置 SpringBoot 默认使用 LogBack 日志系统 默认情况下,SpringBoot项目的日志只会在控制台输入. 如果想查询历史日志则无法找到,我们需要一个日 ...

  3. Python将表格文件中某些列的数据整体向上移动一行

      本文介绍基于Python语言,针对一个文件夹下大量的Excel表格文件,对其中的每一个文件加以操作--将其中指定的若干列的数据部分都向上移动一行,并将所有操作完毕的Excel表格文件中的数据加以合 ...

  4. JavaScript中class的静态属性和静态方法

    我们可以把一个方法赋值给类的函数本身,而不是赋给它的 "prototype" .这样的方法被称为 静态的(static). 例如这样: class Animal { static ...

  5. Node.js开发博客项目笔记-搭建环境(2)

    搭建环境 首先新建blog-1文件夹,在文件夹下初始化package.json,执行命令: npm init -y 生成的package.json文件中的main属性默认值index.js改成bin/ ...

  6. ASP.NET Core – Middleware

    前言 MIddleware 就是中间件, ASP.NET Core 是用来处理 http request 的. 当 request 抵到 server 就进入了 Middleware pipe. 每个 ...

  7. 这10种分布式ID,太绝了!

    前言 分布式ID,在我们日常的开发中,其实使用的挺多的. 有很多业务场景在用,比如: 分布式链路系统的trace_id 单表中的主键 Redis中分布式锁的key 分库分表后表的id 今天跟大家一起聊 ...

  8. cortex-m3 m4 异常机制

    文章写的很好,待整理 1.[STM32]HardFault问题详细分析及调试笔记 https://blog.csdn.net/m0_54916619/article/details/129979222 ...

  9. Spring事务传播机制(最全示例)

    我们在使用Spring框架进行开发时,经常在service层写很多方法,而且这些方法都是带事务的,那么Spring的事务怎么在多个方法之间传播呢?今天我们就仔细聊一聊. Spring的事务传播机制主要 ...

  10. springmvc参数传递不给参数值默认值设置方法

    @RequestMapping("hello") public voiid test001(@RequestParam(defaultValue = "11") ...