【學習筆記】[AGC021F] Trinity

有點難😅

考慮加入每一列,發現我們只關心當前還未確定的行的數目

有點難算😅

d p i , j dp_{i,j} dpi,j?表示有 i i i列,其中 j j j行未確定的方案數。欽定每一列至少有一個黑色格子。

d p i , j = j ( j + 1 ) 2 d p i ? 1 , j + ∑ k ≥ 1 ∑ k ≤ l ≤ j ( j ? l + 1 ) ( l k ) d p i ? 1 , j ? k dp_{i,j}=\frac{j(j+1)}{2}dp_{i-1,j}+\sum_{k\ge 1}\sum_{k\le l\le j}(j-l+1)\binom{l}{k}dp_{i-1,j-k} dpi,j?=2j(j+1)?dpi?1,j?+k1?klj?(j?l+1)(kl?)dpi?1,j?k?

暴力 D P DP DP的復雜度為 O ( N 3 M ) O(N^3M) O(N3M),考慮優化

發現可以看成從 j + 2 j+2 j+2個數中選 k + 2 k+2 k+2個數的方案數,上面的式子其實是在枚舉倒數第二個被選中的數的位置。

d p i , j = j ( j + 1 ) 2 d p i ? 1 , j + ∑ k < j ( j + 2 k ) d p i ? 1 , k dp_{i,j}=\frac{j(j+1)}{2}dp_{i-1,j}+\sum_{k<j}\binom{j+2}{k}dp_{i-1,k} dpi,j?=2j(j+1)?dpi?1,j?+k<j?(kj+2?)dpi?1,k?

這樣優化到了 O ( N 2 M ) O(N^2M) O(N2M)

將組合數拆成階乘的形式,可以用多項式優化。

復雜度 O ( N M log ? N ) O(NM\log N) O(NMlogN)

#include<bits/stdc++.h>
#define fi first
#define se second
#define ll long long
#define pb push_back
#define db double
#define inf 0x3f3f3f3f
using namespace std;
const int mod=998244353;
const int N=8005;
const int M=205;
int n,m;
ll dp[N],res;
ll fac[N],inv[N];
ll fpow(ll x,ll y=mod-2){ll z(1);for(;y;y>>=1){if(y&1)z=z*x%mod;x=x*x%mod;}return z;
}
void init(int n){fac[0]=1;for(int i=1;i<=n;i++)fac[i]=fac[i-1]*i%mod;inv[n]=fpow(fac[n]);for(int i=n;i>=1;i--)inv[i-1]=inv[i]*i%mod;
}
ll binom(int x,int y){if(x<0||y<0||x<y)return 0;return fac[x]*inv[y]%mod*inv[x-y]%mod;
}
void add(ll &x,ll y){x=(x+y)%mod;
}
int len;
ll invlen;
ll omega[N<<2][2];
void ntt(vector<ll>&a,int len,int f=0){int k=0;while((1<<k)<len)k++;for(int i=0;i<len;i++){int t=0;for(int j=0;j<k;j++){if(i>>j&1)t+=(1<<k-j-1);}if(i<t)swap(a[i],a[t]);}for(int l=2;l<=len;l<<=1){int k=l/2;ll x=omega[l][f];for(int i=0;i!=len;i+=l){ll y=1;for(int j=0;j<k;j++){ll tmp=a[i+j+k]*y%mod;a[i+j+k]=(a[i+j]-tmp)%mod;a[i+j]=(a[i+j]+tmp)%mod;y=y*x%mod;}}}if(f)for(int i=0;i<len;i++)a[i]=a[i]*invlen%mod;
}
struct poly{vector<ll>a;friend poly operator *(poly a,poly b){ntt(a.a,len),ntt(b.a,len);for(int i=0;i<len;i++)a.a[i]=a.a[i]*b.a[i]%mod;ntt(a.a,len,1);return a;}
}f,g;
signed main(){ios::sync_with_stdio(false);cin.tie(0),cout.tie(0);cin>>n>>m,init(max(n,m)+2);dp[0]=1;len=1;while(len<=2*(n+2))len<<=1;invlen=fpow(len);omega[len][0]=fpow(3,(mod-1)/len);omega[len][1]=fpow(3,mod-1-(mod-1)/len);for(int i=len/2;i;i>>=1){omega[i][0]=omega[i<<1][0]*omega[i<<1][0]%mod;omega[i][1]=omega[i<<1][1]*omega[i<<1][1]%mod;}g.a.resize(len);for(int i=3;i<=n+2;i++)g.a[i]=inv[i];add(res,1);for(int i=1;i<=m;i++){f.a.clear(),f.a.resize(len);for(int j=0;j<=n;j++)f.a[j]=dp[j]*inv[j]%mod;f=f*g;for(int j=0;j<=n;j++){dp[j]=(j*(j+1)/2*dp[j]%mod+f.a[j+2]*fac[j+2])%mod;}for(int j=0;j<=n;j++)add(res,dp[j]*binom(n,j)%mod*binom(m,i));}cout<<(res+mod)%mod;
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/36797.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/36797.shtml
英文地址,請注明出處:http://en.pswp.cn/news/36797.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

IGV.js 的完全本地化運行探索

問題及解決方法 IGV.js 完全本地化是為了合規&#xff0c;不使用外網的情況下查看基因組。不聯網需要下載 genomes.json 文件及其中的內容之外&#xff0c;還需要修改 igv.js本身&#xff0c;防止5s超時后才顯示網頁內容。修改的關鍵詞是: genomes.json&#xff0c;改為本地的…

Leetcode-每日一題【劍指 Offer 13. 機器人的運動范圍】

題目 地上有一個m行n列的方格&#xff0c;從坐標 [0,0] 到坐標 [m-1,n-1] 。一個機器人從坐標 [0, 0] 的格子開始移動&#xff0c;它每次可以向左、右、上、下移動一格&#xff08;不能移動到方格外&#xff09;&#xff0c;也不能進入行坐標和列坐標的數位之和大于k的格子。例…

一個簡單實用的線程池及線程池組的實現!

1.線程池簡介 線程池&#xff0c;顧名思義&#xff0c;就是一個“池子”里面放有多個線程。為什么要使用線程池呢&#xff1f;當我們編寫的代碼需要并發異步處理很多任務時候&#xff0c;一般的處理辦法是一個任務開啟一個線程去處理&#xff0c;處理結束后釋放線程。可是這樣…

【QT】窗口通過dragEnterEvent和dropEvent拖拽導入文件

【QT】窗口通過dragEnterEvent和dropEvent拖拽導入文件 界面允許接受拖拽 在界面的構造函數中設置接受拖拽放置文件 setAcceptDrops(true); 拖拽進入、放下事件 dragEnterEvent函數對拖動的文件進行過濾&#xff0c;如果不符合過濾條件按將無法拖拽進入窗口 dropEvent函數…

支付總架構解析

一、支付全局分層 一筆支付以用戶為起點&#xff0c;經過眾多支付參與者之后&#xff0c;到達央行的清算賬戶&#xff0c;完成最終的資金清算。那么我們研究支付宏觀&#xff0c;可以站在央行清算賬戶位置&#xff0c;俯視整個支付金字塔&#xff0c;如圖1所示&#xff1a; 圖…

[保研/考研機試] KY135 又一版 A+B 浙江大學復試上機題 C++實現

題目鏈接&#xff1a; KY135 又一版 AB https://www.nowcoder.com/share/jump/437195121691736185698 描述 輸入兩個不超過整型定義的非負10進制整數A和B(<231-1)&#xff0c;輸出AB的m (1 < m <10)進制數。 輸入描述&#xff1a; 輸入格式&#xff1a;測試輸入包…

小米200萬LOGO設計的前端實現技術詳解

引言 小米是一家知名的科技公司&#xff0c;擁有眾多粉絲。其標志性的LOGO是小米200萬像素的文字LOGO&#xff0c;給人留下了深刻的印象。本文將詳細介紹小米200萬LOGO的前端設計實現技術&#xff0c;包括HTML、CSS和JavaScript的使用&#xff0c;以及展示最多的代碼示例。 設…

mysql使用redis+canal實現緩存一致性

一、開啟binlog日志 1.首先查看是否開啟了binlog show variables like %log_bin%; 如果是OFF說明位開啟 2、開啟binlog日志&#xff0c;并重啟mysql服務 右鍵我的電腦——管理——服務——MYSQL——屬性 這里是my.ini地址 在[mysqld]底下添加 log-bin mysqlbinlog binlog-f…

c#設計模式-創建型模式 之 工廠模式

前言&#xff1a; 工廠模式&#xff08;Factory Pattern&#xff09;是一種常用的對象創建型設計模式。該模式的主要思想是提供一個創建對象的接口&#xff08;也可以是抽象類、靜態方法等&#xff09;&#xff0c;將實際創建對象的工作推遲到子類中進行。這樣一來&#xff0c…

【計算機視覺|生成對抗】帶條件的對抗網絡進行圖像到圖像的轉換

本系列博文為深度學習/計算機視覺論文筆記&#xff0c;轉載請注明出處 標題&#xff1a;Image-to-Image Translation with Conditional Adversarial Networks 鏈接&#xff1a;Image-to-Image Translation with Conditional Adversarial Networks | IEEE Conference Publicati…

Spring-2-深入理解Spring 注解依賴注入(DI):簡化Java應用程序開發

今日目標 掌握純注解開發依賴注入(DI)模式 學習使用純注解進行第三方Bean注入 1 注解開發依賴注入(DI)【重點】 問題導入 思考:如何使用注解方式將Bean對象注入到類中 1.1 使用Autowired注解開啟自動裝配模式&#xff08;按類型&#xff09; Service public class StudentS…

HTTP 協議的基本格式和 fiddler 的用法

目錄 一. HTTP 協議 1. HTTP協議是什么 2. HTTP協議的基本格式 HTTP請求 首行 GET和POST方法&#xff1a; 其他方法 經典面試題&#xff1a; URL Header(請求報頭)部分 空行 ?HTTP響應 狀態碼總結: 二、Fiddler的用法 1.Fidder的安裝 2.Fidder的使用 一. HTTP 協議 1. H…

解決macOS執行fastboot找不到設備的問題

背景 最近準備給我的備用機Redmi Note 11 5G刷個類原生的三方ROM&#xff0c;MIUI實在是用膩了。搜羅了一番&#xff0c;在XDA上找到了一個基于Pixel Experience開發的ROM&#xff1a;PixelExperience Plus for Redmi Note 11T/11S 5G/11 5G/POCO M4 Pro 5G (everpal)&#xf…

TMC Self-Managed 提升跨多云環境安全性

作為云原生技術棧的關鍵技術之一&#xff0c;Kubernetes 被企業用戶廣泛試用并開始支撐實際業務應用運行&#xff0c;實現技術先進性帶來的生產力提升。但與此同時&#xff0c;隨著 Kubernetes 技術的不斷廣泛與深化使用&#xff0c;企業用戶也開始面臨諸多技術上的挑戰&#x…

嵌入式:ARM Day1

1. 思維導圖 2.作業一 3.作業2

Android T 窗口層級其二 —— 層級結構樹的構建(更新中)

如何通過dump中的內容找到對應的代碼&#xff1f; 我們dump窗口層級發現會有很多信息&#xff0c;adb shell dumpsys activity containers 這里我們以其中的DefaultTaskDisplayArea為例 在源碼的framework目錄下查找該字符串&#xff0c;找到對應的代碼就可以通過打印堆棧或者…

日常BUG —— Java判空注解

&#x1f61c;作 者&#xff1a;是江迪呀??本文關鍵詞&#xff1a;日常BUG、BUG、問題分析??每日 一言 &#xff1a;存在錯誤說明你在進步&#xff01; 一. 問題描述 問題一&#xff1a; 在使用Java自帶的注解NotNull、NotEmpty、NotBlank時報錯&#xff0c;…

CentOS8安裝Git

錯誤1. 執行yum命令報錯 【錯誤&#xff1a;Invalid configuration value: failovermethodpriority in /etc/yum.repos.d/CentOS-epel.repo; 配置&#xff1a;ID 為 "failovermethod" 的 OptionBinding 不存在】 1.cd /etc/yum.repos.d 2.vim CentOS-epel.repo //…

背上沉重的書包準備面試之react篇

目錄 react特性&#xff1f; react生命周期&#xff1f; state和props區別 react中setState執行機制&#xff1f; 在react類組件形式中&#xff0c;setState第二個參數的作用&#xff1f; react事件機制&#xff1f; react事件綁定方式有哪些&#xff1f; react組件之間…

k8s通過sa和自建角色實現權限精細化分配

文章目錄 權限精細化分配---通過sa和自建角色實現權限精細化分配1.新建sa2.建立一個角色&#xff0c;并將該角色綁定到sa上3.授權namespace的權限,設置ClusterRole和ClusterRolebinding 權限精細化分配—通過sa和自建角色實現權限精細化分配 1.新建sa kubectl create sa lish…