日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

JZOJ 5230. 【NOIP2017模拟A组模拟8.5】队伍统计

發(fā)布時(shí)間:2025/3/15 编程问答 19 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JZOJ 5230. 【NOIP2017模拟A组模拟8.5】队伍统计 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

Description

現(xiàn)在有n個(gè)人要排成一列,編號(hào)為1->n 。但由于一些不明原因的關(guān)系,人與人之間可能存在一些矛盾關(guān)系,具體有m條矛盾關(guān)系(u,v),表示編號(hào)為u的人想要排在編號(hào)為v的人前面。要使得隊(duì)伍和諧,最多不能違背k條矛盾關(guān)系(即不能有超過(guò)k條矛盾關(guān)系(u,v),滿足最后v排在了u前面)。問(wèn)有多少合法的排列。答案對(duì)10^9+7取模。

Input

輸入文件名為count.in。
第一行包括三個(gè)整數(shù)n,m,k。
接下來(lái)m行,每行兩個(gè)整數(shù)u,v,描述一個(gè)矛盾關(guān)系(u,v)。
保證不存在兩對(duì)矛盾關(guān)系(u,v),(x,y),使得u=x且v=y 。

Output

輸出文件名為count.out。
輸出包括一行表示合法的排列數(shù)。

Sample Input

輸入1:

4 2 1
1 3
4 2

輸入2:

10 12 3
2 6
6 10
1 7
4 1
6 1
2 4
7 6
1 4
10 4
10 9
5 9
8 10

Sample Output

輸出1:

18

輸出2:

123120

Data Constraint

對(duì)于30%的數(shù)據(jù),n<=10
對(duì)于60%的數(shù)據(jù),n<=15
對(duì)應(yīng)100%的數(shù)據(jù),n,k<=20,m<=n*(n-1),保證矛盾關(guān)系不重復(fù)。

Solution

  • 看到數(shù)據(jù)范圍,顯然就是狀壓DP了。

  • 設(shè) F[s][i] 表示已經(jīng)選了的人的集合為 s 、已經(jīng)違背了 i 條矛盾關(guān)系 的 合法排列數(shù)。

  • 轉(zhuǎn)移時(shí)枚舉將要選的人,處理出會(huì)產(chǎn)生的矛盾關(guān)系即可。

  • 那么如何快速處理出將會(huì)產(chǎn)生的矛盾關(guān)系呢?

  • 考慮預(yù)處理出 a[x] 表示排在 x 以前會(huì)有矛盾的人的集合,

  • 那么與 s & 的值二進(jìn)制的 1 的個(gè)數(shù)就是所求的數(shù)量了。

  • 時(shí)間復(fù)雜度為 O(2N?N?K)

Code

#include<cstdio> using namespace std; const int mo=1e9+7; int n,m,k,ans; int a[21],g[1<<20],p[21],f[1<<20][21]; inline int read() {int X=0,w=1; char ch=0;while(ch<'0' || ch>'9') {if(ch=='-') w=-1;ch=getchar();}while(ch>='0' && ch<='9') X=(X<<3)+(X<<1)+ch-'0',ch=getchar();return X*w; } inline void dfs(int x,int y,int z) {if(z>n) return;g[x]=y;dfs(x,y,z+1);dfs(x+p[z],y+1,z+1); } int main() {n=read(),m=read(),k=read();for(int i=p[0]=1;i<=n;i++) p[i]=p[i-1]<<1;dfs(0,0,0);for(int i=1;i<=m;i++){int x=read(),y=read();a[y]|=p[x-1];}f[0][0]=1;for(int s=0;s<p[n];s++)for(int j=1;j<=n;j++)if(p[j-1]&s){int sum=g[s&a[j]];for(int i=sum;i<=k;i++) f[s][i]=(f[s][i]+f[s-p[j-1]][i-sum])%mo;}for(int i=0;i<=k;i++) ans=(ans+f[p[n]-1][i])%mo;printf("%d",ans);return 0; }

總結(jié)

以上是生活随笔為你收集整理的JZOJ 5230. 【NOIP2017模拟A组模拟8.5】队伍统计的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产尤物在线视频 | av男人天堂av | 2018天天弄 | 欧美xxxxxx片免费播放软件 | 国产又粗又黄又爽又硬 | 91桃色污| 视频一区三区 | www.国产视频.com | 中文字幕一区二区三区人妻 | 日韩欧美极品 | 中国女人毛茸茸 | 欧美成人免费在线观看 | av狠狠| 国产精品伦一区 | 一本久道久久综合 | 欧美xxxx83d| 国产一线天粉嫩馒头极品av | 国产精品一区免费 | 亚洲播放器| 欧美在线小视频 | 乱亲女h秽乱长久久久 | 欧美老少做受xxxx高潮 | 国产国语videosex另类 | 91免费片| 91人人视频| 97精品一区二区视频在线观看 | 精品一区二区日韩 | 美女被c出水 | 在线免费观看视频a | 中文字幕无码精品亚洲资源网久久 | 日本精品区 | 99精品久久99久久久久 | 国产做爰xxxⅹ性视频国 | 国产成人精品在线视频 | 亚洲av综合色区无码一二三区 | 五个女闺蜜把我玩到尿失禁 | 人妻无码一区二区三区免费 | 九热在线 | 黄色美女毛片 | 污免费在线观看 | 99热网址| 欧美人与禽zozzo禽性配 | 草莓视频在线观看入口w | 91看片视频 | 丰满熟妇人妻av无码区 | 在线国产播放 | 亚洲自拍偷拍网 | 国产精品人人 | 麻豆av网| 嫩草视频一区二区三区 | 欧美精品在欧美一区二区 | 婷婷影视 | 成人午夜视频在线观看 | 麻豆av电影在线 | 内地毛片| 欧洲精品在线观看 | 欧美男女性生活视频 | av导航大全 | 爆操网站 | 饥渴放荡受np公车奶牛 | 91热在线 | 日本免费精品视频 | 96视频在线 | 日产精品久久久久久久蜜臀 | 午夜视频在线观看一区二区 | 国产精品视频免费观看 | 张柏芝54张无删码视频 | 在线观看国产免费视频 | 一区二区在线视频观看 | 蜜臀少妇久久久久久久高潮 | 久久精品视频在线观看 | 亚洲一区二区视频 | 伊人99re| 亚洲欧美日本在线 | 日本高清有码视频 | 日韩欧美精品在线观看 | 可以免费看黄的网站 | 亚洲免费一二三区 | 夏晴子在线 | 级毛片内射视频 | www国产精品内射熟女 | 天堂一区在线观看 | 毛片a| 啪在线视频 | 欧美视频二区 | 日本黄色免费网址 | 久久夜色精品国产欧美乱极品 | 日韩人妻精品无码一区二区三区 | 黄色a级在线观看 | www.黄色片.com | 亚洲天堂男人的天堂 | 欧美日韩在线二区 | 亚洲蜜臀av| 中文字幕精品三级久久久 | 美女av影院 | 免费精品在线视频 | xxx日本少妇 | 一级中国毛片 | 亚洲天堂av中文字幕 |