2019.03.27【GDOI2019】模擬 T3

題目大意

給出$n$, $p$, 求有多少長度為$n$的排列可以被分成三個上升子序列, 數量對$p$取模,

數據范圍 $3 \leq n \leq 500$.

思路

首先讓我們考慮如果有一個排列,如何判斷這個排列合法,我可以考慮貪心,維護三個上升序列的末尾(最大值),從左到右依次將數插入序列,把這個數貪心的加到它可以加入的末尾的數最大的序列里.

因此考慮dp,定義$f[i][j][k]$表示現在有$i$個數,形成了三個上升子序列,其中最大的子序列末尾顯然是第$i$大的數,第二大的子序列末尾是第$j$大的數,第三大的子序列末尾是第$k$大的數,這樣的序列的數量,顯然,這樣枚舉是不會重復的,轉移的時候,考慮在這個序列末尾加數,考慮加的這個數在這$i$個數中的相對位置,設這個位置為$l$,有
$$
f[i][j][k] \rightarrow f[i+1][j][k],l=i+1 \\
f[i][j][k] \rightarrow f[i+1][l][k],j < l \leq i \\
f[i][j][k] \rightarrow f[i+1][j+1][l], k < l \leq j
$$
一個簡單的$O(n^4)$dp

#define add(x, y) x = (x + y >= md) ? x + y - md : x + y
f[1][0][0] = 1;
for (int i = 1; i < n; ++i)for (int j = 0; j < i; ++j)for (int k = 0; k <= j; ++k)if (f[i][j][k] > 0) {int x = f[i][j][k];for (int l = k + 1; l <= j; ++l)add(f[i + 1][j + 1][l], x);for (int l = j + 1; l <= i; ++l)add(f[i + 1][l][k], x);add(f[i + 1][j][k], x);}

考慮優化,發現轉移的都是一段,隨便前綴和搞一搞就可以了

#define add(x, y) x = (x + y >= md) ? x + y - md : x + y
#define sub(x, y) x = (x - y < 0) ? x - y + md : x - y
f[1][0][0] = 1;
for (int i = 1; i < n; ++i) {int cur = i & 1, nxt = cur ^ 1;memset(f[nxt], 0, sizeof(f[nxt]));memset(tag1, 0, sizeof(tag1));memset(tag2, 0, sizeof(tag2));for (int j = 0; j < i; ++j)for (int k = 0; k <= j; ++k) if (f[cur][j][k] > 0) {int x = f[cur][j][k];add(tag1[j + 1][k + 1], x);sub(tag1[j + 1][j + 1], x);add(tag2[j + 1][k], x);sub(tag2[i + 1][k], x);add(f[nxt][j][k], x);}for (int j = 0; j <= i; ++j)for (int k = 1; k <= i; ++k)add(tag1[j][k], tag1[j][k - 1]), add(tag2[k][j], tag2[k - 1][j]);for (int j = 0; j <= i; ++j)for (int k = 0; k <= j; ++k) {add(f[nxt][j][k], tag1[j][k]);add(f[nxt][j][k], tag2[j][k]);} 
}

復雜度$O(n^3)$.

轉載于:https://www.cnblogs.com/withoutpower/p/10616499.html

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

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

相關文章

DOM的那些事

到底調用函數時要不要加&#xff08;&#xff09;&#xff1f; 在html中&#xff0c;onclick后必須接字符串調用&#xff0c;而在js中則必須接函數進行調用。 addEventListener和click區別 onclick只是一個屬性&#xff0c;且是唯一的。其只能綁定一個事件&#xff0c;容易在不…

真格量化-隱含波動率購買

# coding:utf-8 #!/usr/bin/env python from PoboAPI import * import datetime import numpy as np #50ETF 和 50ETF期權的對沖交易,當ETF隱含波動率較高時就買50ETF并做空50ETF看漲期權#開始時間,用于初始化一些參數 def OnStart(context) :print("system starting...…

能讓你成為更優秀程序員的10個C語言資源

本文由 伯樂在線 - archychu 翻譯自 mycplus。歡迎加入 技術翻譯小組。轉載請參見文章末尾處的要求。一些人覺得編程無聊&#xff0c;一些人覺得它很好玩。但每個程序員都必須緊跟編程語言的潮流。大多數程序員都是從C開始學習編程的&#xff0c;因為C是用來寫操作系統、應用程…

解決 -- 代碼沒有問題時接口報錯:Status Code: 404 Not Found

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 我能確定這個工程的接口代碼肯定沒有問題&#xff0c;這時請求接口依舊報 404。 如&#xff1a; 經過多方檢查 最終確認問題原因&…

滲透測試學習

滲透學習路線&#xff1a;https://www.sec-wiki.com/skill/2 經常應該瀏覽的網站&#xff1a;www.freebuf.comdrops.wooyun.orgwww.sec-wiki.com/www.t00ls.net/www.91ri.orghttp://fex.baidu.com/blog/2014/05/what-happen/了解了web訪問網頁的基本過程http://www.qianxingzhe…

java版開源工作流引擎ccflow從表數據數據源導入設置

為什么80%的碼農都做不了架構師&#xff1f;>>> 關鍵字馳騁工作流引擎 流程快速開發平臺 workflow ccflow jflow .net開源工作流 從表數據導入設置 概要說明在從表的使用中我一般都會用到從數據庫引入一些數據到表單中&#xff0c;這時候就需要有一個功能能夠查詢…

真格量化——中性策略交易期權

#!/usr/bin/env python # coding:utf-8 from PoboAPI import * import datetime import time import numpy as np from copy import *import pandas as pd #設定持倉細節數據表 #g.df = {}g.df = pd.DataFrame(columns = [date,code,price,volume,stoploss,iv]) g.a = [] g.b =…

一周消息樹:程序員想找好工作?那就學好Linux!

摘要&#xff1a;從一小眾化的系統發展到今天在國際上支撐著絕大部分公司的重量級系統&#xff0c;Liunx現在被越來越多的公司重視。而Linux人才卻沒有跟上&#xff0c;為此&#xff0c;MongoDB公司的副總裁Matt Asay給軟件開發者們一個建議&#xff1a;要學好Linux。 近期&…

注解@Cacheable(value =“XXX“) 實現緩存 -- 失效原因

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 一個項目中使用到了注解緩存&#xff0c;但無論怎么檢查都不生效&#xff0c;反復確認緩存的使用本身應該沒有出錯。 最后確認原因&…

讀書筆記011:《傷寒論》- 手厥陰心包經

手厥陰心主起胸&#xff0c;屬包下膈三焦宮&#xff0c;支者循胸出脅下&#xff0c;脅下連腋三寸同。仍上抵腋循臑內&#xff0c;太陰、少陰兩經中&#xff0c;指透中沖支者別&#xff0c;小指次指絡相通。此經少氣原多血&#xff0c;是動則病手心熱&#xff0c;肘臂攣急腋下腫…

真格量化——做空波動率賣期權策略

# coding:utf-8 #!/usr/bin/env python # EmuCounter2 from PoboAPI import * import datetime import numpy as np#開始時間,用于初始化一些參數 def OnStart(context) :print "system starting..."#設定全局變量品種g.code1 = "m1901-C-3300.DCE" #豆粕…

支撐4.5億活躍用戶的WhatsApp架構概覽

摘要&#xff1a;不顧谷歌CEO阻攔&#xff0c;WhatsApp最終以190億美元的價格花落Facebook。能獲如此天價與其月4.5億的活躍用戶是分不開的&#xff0c;同樣不可或缺的還有支撐每日數百億消息的高可靠架構。 【編者按】以190億美元的價格出售給Facebook&#xff0c;交易談判過…

C++ 常用函數總結

平時常用C刷一些算法題&#xff0c;C內置了許多好用的工具函數&#xff0c;但時間一長總是容易忘記&#xff0c;這里簡單做一下總結&#xff0c;方便復習&#xff01; <stdlib.h> atoi(const char* str)將一串字符轉換為int型atof(const char* str)同上&#xff0c;轉換為…

注解驅動的 Spring cache 緩存介紹

概述 前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 Spring 3.1 引入了激動人心的基于注釋&#xff08;annotation&#xff09;的緩存&#xff08;cache&#xff09;技術&#xff0c;…

真格量化——50etf與期權對沖策略

# coding:utf-8 #!/usr/bin/env python from PoboAPI import * import datetime import numpy as np #50ETF 和 50ETF期權的對沖交易,當ETF隱含波動率較高時就買50ETF并做空50ETF看漲期權#開始時間,用于初始化一些參數 def OnStart(context) :print("system starting...…

如何用Linux命令行管理網絡:11個你必須知道的命令

本文由 極客范 - jerrylee 翻譯自 Chris Hoffman。歡迎加入極客翻譯小組&#xff0c;同我們一道翻譯與分享。轉載請參見文章末尾處的要求。無論你是要下載文件、診斷網絡問題、管理網絡接口&#xff0c;還是查看網絡的統計數據&#xff0c;都有終端命令可以來完成。這篇文章收…

運營商市場經營方向及趨勢

中電信、中聯通、中移動三大運營商可以說在行業內都是大名鼎鼎的&#xff0c;不管是產品、服務及發展等趨勢都在友好、積極的環境下持續發酵、有效發展中。 處于上海地區的三大運營商指定一級代理商威禹通信在近期&#xff0c;也頻頻感受到三大運營商的動作&#xff0c;有效&am…

真格量化——50期權歷史波動率策略

#!/usr/bin/env python # coding:utf-8 from PoboAPI import * import datetime import time import numpy as np #日線級別 #開始時間,用于初始化一些參數 def OnStart(context) :print("I\m starting...")#設定一個全局變量品種,本策略交易50ETF期權g.code = &quo…

10 張圖帶你深入理解Docker容器和鏡像

此文中部分信息、圖片需要 fan qiang , 如果未能正常顯示&#xff0c;文末有原文連接 。【Kubernetes培訓通知】DockOne將會于2018年5月18日在上海舉辦Kubernetes技術培訓&#xff0c;培訓內容包括&#xff1a;容器介紹、容器網絡、Kubernetes架構基礎介紹、安裝、設計理念、架…

k8s強制刪除pod

有時候pod一直在Terminating kubectl delete pod xxx --force --grace-period0 轉載于:https://www.cnblogs.com/floud/p/10620783.html