Solution -「NWRRC 2017」「洛谷 P7024」Fygon 2.0
\(\mathcal{Description}\)
Link.
给定一个无并列语句的多重循环,每个变量取值的左端点只能是 \(1\) 或已定义的变量;右端点只能是 \(n\) 或已定义的变量。求循环语句关于 \(n\) 的复杂度以及常数。
循环语句数量 \(m<20\)。
\(\mathcal{Solution}\)
按变量的偏序关系建图,缩掉 SCC——它们的取值必然相等,设有 \(s\) 个 SCC,那么循环的复杂度显然是 \(\mathcal O(n^s)\),难点在于求常数。
第一步转化是平凡的:我们可以钦定变量间的严格偏序而忽略取等的情况。这是因为当某两个变量取等时,不会对计算次数的最高次产生贡献。此外,我们还能得知在变量都取 \([1,n]\),但被限制偏序时,一共有 \(s!\binom{n}{s}\) 种取值组。
第二步,利用缩点得到的 DAG 的性质,可以发现:在严格偏序意义下,满足 DAG 限制的变量组数量等于对 DAG 拓扑排序的方案数。 证明是平凡的。设方案数为 \(c\),由此可知 \(\frac{c}{s!}\) 即循环的常数因子。
求解复杂度为 \(\mathcal O(2^mm^2)\),瓶颈是状压求拓扑方案数。也许能优化 awa。(
\(\mathcal{Code}\)
/*+Rainybunny+*/
#include <bits/stdc++.h>
#define rep( i, l, r ) for ( int i = l, rep##i = r; i <= rep##i; ++i )
#define per( i, r, l ) for ( int i = r, per##i = l; i >= per##i; --i )
typedef long long LL;
inline void chkmin( int& u, const int v ) { v < u && ( u = v ); }
inline LL gcd( const LL u, const LL v ) { return v ? gcd( v, u % v ) : u; }
const int MAXN = 20;
int n, adj[MAXN + 5], vad[MAXN + 5], ref[256];
int scc, dfc, dfn[MAXN + 5], low[MAXN + 5], bel[MAXN + 5];
LL f[1 << MAXN];
inline void tarjan( const int u ) {
static int stk[MAXN + 5], top;
static bool instk[MAXN + 5];
instk[stk[++top] = u] = true, dfn[u] = low[u] = ++dfc;
rep ( v, 0, n - 1 ) if ( adj[u] >> v & 1 ) {
if ( !dfn[v] ) tarjan( v ), chkmin( low[u], low[v] );
else if ( instk[v] ) chkmin( low[u], dfn[v] );
}
if ( dfn[u] == low[u] ) {
int v;
do instk[v = stk[top--]] = false, bel[v] = scc; while ( v != u );
++scc;
}
}
int main() {
freopen( "fygon20.in", "r", stdin );
freopen( "fygon20.out", "w", stdout );
scanf( "%d%*c", &n ), --n;
if ( !n ) return puts( "0 1/1" ), 0;
rep ( i, 0, n - 1 ) {
static char str[200]; int st = i << 2;
scanf( "%[^\n]%*c", str ), ref[str[st + 4]] = i;
if ( str[st + 15] != '1' ) adj[i] |= 1 << ref[str[st + 15]];
if ( str[st + 18] != 'n' ) adj[ref[str[st + 18]]] |= 1 << i;
}
rep ( i, 0, n - 1 ) if ( !dfn[i] ) tarjan( i );
rep ( u, 0, n - 1 ) rep ( v, 0, n - 1 ) {
if ( adj[u] >> v & 1 && bel[u] != bel[v] ) {
vad[bel[u]] |= 1 << bel[v];
}
}
f[0] = 1;
rep ( S, 0, ( 1 << scc ) - 2 ) {
rep ( u, 0, scc - 1 ) if ( ~S >> u & 1 ) {
bool flg = true;
rep ( v, 0, scc - 1 ) {
flg &= !( v != u && ~S >> v & 1 && vad[v] >> u & 1 );
if ( !flg ) break;
}
if ( flg ) f[S | 1 << u] += f[S];
}
}
LL fac = 1;
rep ( i, 1, scc ) fac *= i;
LL d = gcd( fac, f[( 1 << scc ) - 1] );
printf( "%d %lld/%lld\n", scc, f[( 1 << scc ) - 1] / d, fac / d );
return 0;
}
Solution -「NWRRC 2017」「洛谷 P7024」Fygon 2.0的更多相关文章
- 「区间DP」「洛谷P1043」数字游戏
「洛谷P1043」数字游戏 日后再写 代码 /*#!/bin/sh dir=$GEDIT_CURRENT_DOCUMENT_DIR name=$GEDIT_CURRENT_DOCUMENT_NAME ...
- [CodePlus 2017 11月赛&洛谷P4058]木材 题解(二分答案)
[CodePlus 2017 11月赛&洛谷P4058]木材 Description 有 n棵树,初始时每棵树的高度为 Hi ,第 i棵树每月都会长高 Ai.现在有个木料长度总量为 S的订单, ...
- Solution -「JSOI 2019」「洛谷 P5334」节日庆典
\(\mathscr{Description}\) Link. 给定字符串 \(S\),求 \(S\) 的每个前缀的最小表示法起始下标(若有多个,取最小的). \(|S|\le3\time ...
- Solution -「洛谷 P4372」Out of Sorts P
\(\mathcal{Description}\) OurOJ & 洛谷 P4372(几乎一致) 设计一个排序算法,设现在对 \(\{a_n\}\) 中 \([l,r]\) 内的元素排 ...
- Solution -「POI 2010」「洛谷 P3511」MOS-Bridges
\(\mathcal{Description}\) Link.(洛谷上这翻译真的一言难尽呐. 给定一个 \(n\) 个点 \(m\) 条边的无向图,一条边 \((u,v,a,b)\) 表示从 ...
- Solution -「APIO 2016」「洛谷 P3643」划艇
\(\mathcal{Description}\) Link & 双倍经验. 给定 \(n\) 个区间 \([a_i,b_i)\)(注意原题是闭区间,这里只为方便后文描述),求 \(\ ...
- 「洛谷4197」「BZOJ3545」peak【线段树合并】
题目链接 [洛谷] [BZOJ]没有权限号嘤嘤嘤.题号:3545 题解 窝不会克鲁斯卡尔重构树怎么办??? 可以离线乱搞. 我们将所有的操作全都存下来. 为了解决小于等于\(x\)的操作,那么我们按照 ...
- 「洛谷3338」「ZJOI2014」力【FFT】
题目链接 [BZOJ] [洛谷] 题解 首先我们需要对这个式子进行化简,否则对着这么大一坨东西只能暴力... \[F_i=\sum_{j<i} \frac{q_iq_j}{(i-j)^2}-\s ...
- 「BZOJ2733」「洛谷3224」「HNOI2012」永无乡【线段树合并】
题目链接 [洛谷] 题解 很明显是要用线段树合并的. 对于当前的每一个连通块都建立一个权值线段树. 权值线段树处理操作中的\(k\)大的问题. 如果需要合并,那么就线段树暴力合并,时间复杂度是\(nl ...
随机推荐
- vue - 指令创建 vue工程
1.在需要创建工程的文件夹里打开cmd 执行 vue -V 看看版本号是否正常, 创建工程 vue create [工程名称] 如:vue create mytestvue 然后会弹出选择 按方向键, ...
- ON UPDATE CURRENT_TIMESTAMP请慎用
大家好,我是架构摆渡人.这是实践经验系列的第七篇文章,这个系列会给大家分享很多在实际工作中有用的经验,如果有收获,还请分享给更多的朋友. 今天给大家分享一个容易忽略的问题,正是因为容易忽略,所以才要重 ...
- 帮你克服web字体选择焦虑症
1.背景 前端时间产品经理问我,移动端web默认字体有哪些,哪些字体不侵权?我当时感觉这方面的知识很匮乏,只能回答出微软雅黑和苹方简体,平常写代码时,没怎么留意过font-family设置的字体属性, ...
- 第3届云原生技术实践峰会(CNBPS 2020)重磅开启,“原”力蓄势待发!
CNBPS 2020将在11月19-21日全新启动!作为国内最有影响力的云原生盛会之一,云原生技术实践峰会(CNBPS)至今已举办三届. 在2019年的CNBPS上,灵雀云CTO陈恺喊出"云 ...
- Mysql存储过程二
1.MySQL中创建存储过程时通过DEFINER和SQL SECURITY设置访问权限 procedure与function.trigger等创建时紧接着CREATE都有个definer可选项,该de ...
- Go环境配置和GoModule
Linux相关 Linux常用操作 mkdir directory --创建文件夹 vi file --创建文件,再关闭vim rm file --删除文件 rm -rf directory --递归 ...
- 【笔记】macos上部署thanos_receiver + thanos_query
为了方便起见,在mac笔记本上进行了测试 1.写一个发送数据的客户端 package main import ( "fmt" "io/ioutil" " ...
- [Anti-AV] 从攻防对抗辩证性分析jsp免杀(一)
从攻防对抗辩证性分析jsp免杀 从最早的最朴素木马 <%@ page import="java.io.InputStream" %> <%@ page impor ...
- 一、neo4j中文文档-入门指南
目录 neo4j中文文档-入门指南 Neo4j v4.4 neo4j **Cypher ** 开始使用 Neo4j 1. 安装 Neo4j 2. 文档 图数据库概念 1. 示例图 2.节点 3. 节点 ...
- bit操作常见trick
x&(x-1)可以消去最右边的1, 如果判断一个数是否是2的指数的快捷方法,比如8,二进制位1000, 那么8&(8-1)为0,只要为0就是2的指数