P3193 [HNOI2008]GT考試

傳送門

容易看出是道DP

考慮一位一位填數字

設 f [ i ] [ j ] 表示填到第 i 位,在不吉利串上匹配到第 j 位時不出現不吉利數字的方案數

設 g [ i ] [ j ] 表示不吉利串匹配到第 i 位,再添加一個數字,使串匹配到第 j 位的方案數

那么方程顯然為 :?

?

注意我們不需要考慮 $j=m$ 的情況,因為 $j=m$時肯定已經出現匹配了

顯然我們可以預處理出 g ,然后直接轉移

最后答案就是?

?

還有一個問題,n 太大了

發現 g 是固定的,把 g 搞成矩陣直接矩陣加速一下

復雜度$ O(log_n)$

#include<cstdio>
#include<algorithm>
#include<cmath>
#include<cstring>
#include<iostream>
using namespace std;
typedef long long ll;
inline int read()
{int x=0,f=1; char ch=getchar();while(ch<'0'||ch>'9') { 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=27;
int n,m,mo;
inline int fk(int x) { return x>=mo ? x-mo : x; }
int a[N],fail[N];
char s[N];
int g[N][N];
struct matrix//矩陣不解釋
{int a[N][N];matrix () { memset(a,0,sizeof(a)); }inline matrix operator * (const matrix &tmp) const {matrix res;for(int i=0;i<m;i++)for(int j=0;j<m;j++)for(int k=0;k<m;k++)res.a[i][j]=fk(res.a[i][j]+a[i][k]*tmp.a[k][j]%mo);return res;}
}F,M;
inline matrix ksm(matrix x,int y)//矩陣快速冪不解釋
{matrix res;for(int i=0;i<=m;i++) res.a[i][i]=1;while(y){if(y&1) res=res*x;x=x*x; y>>=1;}return res;
}
inline void pre()//預處理,本人閑的蛋疼用kmp預處理g
{int x=0; fail[0]=-1;for(int i=1;i<=m;i++){x=fail[i-1]; while(x!=-1&&a[x+1]!=a[i]) x=fail[x];fail[i]=x+1;}fail[0]=0;for(int i=0;i<m;i++)for(int j=0;j<10;j++)//枚舉填的每個數字,看看能匹配到哪里
        {x=i; while(x&&a[x+1]!=j) x=fail[x];g[i][a[x+1]==j ? x+1 : x]++;//把匹配到的位置++
        }for(int i=0;i<m;i++) for(int j=0;j<m;j++) M.a[i][j]=g[i][j];//轉移矩陣就是g
}
int main()
{n=read(); m=read(); mo=read();scanf("%s",s+1);for(int i=1;i<=m;i++) a[i]=s[i]-'0'; a[m+1]=a[0]=-1;//閑的蛋疼,就是愛轉數字pre(); F.a[0][0]=1;//初始狀態F=F*ksm(M,n); int ans=0;for(int i=0;i<m;i++) ans=fk(ans+F.a[0][i]);printf("%d",ans);return 0;
}

?

轉載于:https://www.cnblogs.com/LLTYYC/p/9907548.html

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

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

相關文章

LeetCode刷題攻略

目錄 一、LeetCode簡介 二、刷leetcode的主要目的 三、常用的數據結構 四、常用的算法思想 五、選擇算法題 1、刷題選擇 2、刷題方法 方法一&#xff1a;順序法 方法二&#xff1a;標簽法 方法三&#xff1a;隨機法 方法四&#xff1a;必殺法 六、刷題攻略 TIP 1&…

SQLserver數據庫反編譯生成Hibernate實體類和映射文件

一、建立項目和sqlserver數據庫 eclipse&#xff0c;我使用的版本是neon3 二、Data Source Explorer 選擇OK 在data source Explorer的Database Connections 選擇New 填寫好General的連接信息 新建New Driver Definition 填寫完選擇OK 選擇剛才的Drivers Test Connetion測試 N…

最受歡迎的5大Linux發行版

摘要&#xff1a;要統計有多少人在使用那款Linux發行版幾乎是不可能的事情&#xff0c;但我們可以使用一些在線分析工具來大概地看看哪些Linux發行版更受歡迎。 Google Trends的數據顯示&#xff0c;Ubuntu用戶正在流向Mint&#xff0c;但依然在各方面都比其它Linux發行版更有優…

C#動態操作DataTable(新增行、列、查詢行、列等)

public void CreateTable(){//創建表DataTable dt new DataTable();//1、添加列dt.Columns.Add("Name", typeof(string)); //數據類型為 文本//2、通過列架構添加列DataColumn age new DataColumn("Age", typeof(Int32)); //數據類型為 整形DataColumn…

使用IntelliJ IDEA 配置Maven(入門)

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 1. 下載Maven 官方地址&#xff1a;http://maven.apache.org/download.cgi 解壓并新建一個本地倉庫文件夾 2.配置本地倉庫路徑 3.配…

[算法]不使用*、/、+、-、%操作符求一個數的1/3

摘要&#xff1a;算法一直是程序員進階的一道龍門&#xff0c;通常算法都是為了更高效地解決問題而創造的&#xff0c;但也有的只是出于學術性&#xff0c;并不在意其實際意義。這是近日在國外技術問答網站stackoverflow的一個熱門問題&#xff0c;不知道你能給出幾種解決方法&…

2022屆互聯網秋招備戰

文章目錄1、何為秋招&#xff1f;1.1應屆生身份1.2秋招、春招、校招1.3、社招、海投2.秋招信息如何獲取&#xff1f;3、如何備戰秋招&#xff1f;3.1、簡歷&#xff08;ps做簡歷&#xff09;3.2、筆試準備3.3、面試準備4、日常實習和暑假實習&#xff1f;1、春招≠暑期實習2、什…

php 兩變量值互換 方法

//方法一&#xff1a;$a "abc";$b"def";$a $a^$b;$b $b^$a;$a $a^$b;//方法二&#xff1a;list($a, $b) array($b, $a);//方法三&#xff1a;$a $a . $b;$b strlen( $b );$b substr( $a,0,(strlen($a)- $b ));$a substr( $a, strlen($b));//方法四&…

MySQL5.7 group by新特性,報錯1055

項目中本來使用的是mysql5.6進行開發&#xff0c;切換到5.7之后&#xff0c;突然發現原來的一些sql運行都報錯&#xff0c;錯誤編碼1055&#xff0c;錯誤信息和sql_mode中的“only_full_group_by“關&#xff0c;到網上看了原因&#xff0c;說是mysql5.7中only_full_group_by這…

IDEA中多行注釋及取消注釋快捷鍵

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 1、一次性添加多行注釋的快捷鍵 首先選中要注釋區域&#xff0c;然后 ctrl/ 這個是多行代碼分行注釋&#xff0c;每行一個注釋…

為什么程序員不擅長估算時間?

摘要&#xff1a;時間估算是困難的&#xff0c;每一個程序員都有一個現實的估計區間&#xff0c;低于這個區間的估計意味著&#xff08;構件&#xff0c;測試&#xff0c;檢查代碼的&#xff09;時間開銷被低估了&#xff0c;超過這個區間的估計意味著這個任務太大而很難預估。…

red hat enterprise linux 7關閉防火墻的方法

2019獨角獸企業重金招聘Python工程師標準>>> red hat enterprise linux 7發布后&#xff0c;發現防火墻也變了&#xff0c;如何關閉防火墻呢&#xff0c;下面是方法 1.查看firewall的狀態 [rootsztech7 ~]# systemctl status firewalld firewalld.service - firewal…

IOS —— 網絡那些事(上) - http協議

作為一名并不太合格的程序員&#xff0c;今天要分享學習的成果&#xff0c;竟然講的是網絡相關HTTP協議的事情。&#xff08;也算是復習了&#xff09; 乍看HTTP協議的內容著實是十分復雜的&#xff0c;涉及到十分多互聯網"底層"框架的東西。今天就先撇開這部分詳細內…

【最新版】Java速成路線(急于找工作!)

文章目錄計算機網絡分層結構TCP/UDPHTTP/HTTPS狀態碼Cookie 和 SessionURI和URL操作系統線程和進程數據結構和算法數據結構算法設計模式&#xff08;23種&#xff09;單例工廠代理適配器觀察者模板實操工具Git/SVNMaven/GradleLinux基本操作NginxELKpostmanJAVA基礎語言基礎JVM…

Java Web Start實例

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 JWS讓用戶可以下載服務器端的Java Application到本機運行&#xff0c;并且沒有安裝、配置等繁瑣的操作JWS的運行原理&#xff1a;瀏覽器…

老派程序員——徒手實現偉大成就

摘要&#xff1a;本文介紹了三位非常著名的程序員&#xff1a;Ken Thompson,Joe Armstrong 和 Jamie Zawinski&#xff0c;他們是如何發明一門新語言&#xff0c;他們開發軟件時會像我們一樣使用當今流行的開發工具嗎&#xff1f;當讀Peter Seibel的精彩著作《編程人生:15位軟件…

互聯網大廠項目研發流程

文章目錄階段一&#xff1a;階段二&#xff1a;階段三&#xff1a;階段四&#xff1a;階段五&#xff1a;開發人員&#xff1a;測試人員&#xff1a;設計師&#xff1a;階段六&#xff1a;階段七&#xff1a;總結&#xff1a;本文章學習自&#xff1a;https://www.bilibili.com…

centos常見錯誤 Failed to set locale, defaulting to C

錯誤描述&#xff1a; 當在centos中使用yum命令時&#xff0c;輸出錯誤&#xff1a; [rootlocalhost yum.repos.d]# yum list |grep prceFailed to set locale, defaulting to C 用locale檢測&#xff0c;出現如下提示&#xff1a; rootlocalhost yum.repos.d]# localelocale: …

圖片上傳知識點梳理

在日常項目開發中&#xff0c;圖片上傳是一個十分常見的場景。而現在的各種UI框架都提供了自己的上傳組件&#xff0c;網上第三方的上傳組件也多如牛毛。可能你早已習慣了直接使用這些現成的組件&#xff0c;然而對于其具體的實現&#xff0c;卻并未深入解析。本文將通過簡單的…

解決 java.lang.IllegalArgumentException: Repository interface must not be null on initialization!

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 報錯&#xff1a;Caused by: java.lang.IllegalArgumentException: Repository interface must not be null on initialization! Cause…