\(\mathcal{Description}\)

  给定 \(\{a_n\}\),求一个 \(\{b_{n-1}\}\),使得 \(\forall x\in\{a_n\},\exists i,j\in[1,n),b_i+b_j=x\)。输出 \(\{b_{n-1}\}\) 以及对于每个 \(x\) 所应该取的 \(i,j\),或断言不可能。

  \(n\le30\)。

\(\mathcal{Solution}\)

  原来不是构造题啊。(悲

  若 \(a\) 中有偶数 \(2k\),取一个 \(b=k\),然后随便填就好,先特判掉。

  考虑已有了 \(\{b_{n-1}\}\),对于某个 \(b_i+b_j=a_k\),在 \(b_i\) 与 \(b_j\) 之间连接一条权为 \(a_k\) 的边。显然,这些边最终构成了 \(n-1\) 个点 \(n\) 条边的图,必然存在偶环。不妨设环上的 \(b\) 为 \(b_1,b_2,\cdots,b_k\),边权为 \(a_1,a_2,\cdots,a_k\),则应有

\[\begin{cases}b_1+b_2=a_1\\b_2+b_3=a_2\\\dots\\b_k+b_1=a_k\end{cases}
\]

可以钦定 \(b_1=0\),剩下 \(k-1\) 个变量和 \(k\) 个方程,结合环的形状分析发现有解当且仅当 \(\sum_{2\mid i}a_i=\sum_{2\not\mid i}a_i\)。所以用 MiM 在 \(\{a_n\}\) 中找两个等大等和且不交的子集用于构造即可。

  假设 Hash 的复杂度为 \(\mathcal O(1)\),则最终复杂度为 \(\mathcal O(3^\frac{n}{2})\)。

\(\mathcal{Code}\)

  比较卡 qwq。

/* Clearink */

#include <cstdio>
#include <vector>
#include <cassert>
#include <cstdlib> #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; const int MAXN = 30;
const LL INF = 1e11;
int n, half, pwr[20], ans[MAXN + 5];
LL a[MAXN + 5], b[MAXN + 5]; static const int M = 100000037, MAXND = 1.5e7;
int node, head[M], val[MAXND], nxt[MAXND];
LL key[MAXND]; inline int& get( const LL k ) {
int r = head[( k % M + M ) % M], las = -1;
for ( ; r && key[r] != k; r = nxt[las = r] );
if ( r ) return val[r];
if ( !~las ) head[( k % M + M ) % M] = r = ++node;
else nxt[las] = r = ++node;
return key[r] = k, val[r] = -1;
} inline bool count( const LL k ) {
int r = head[( k % M + M ) % M], las = -1;
for ( ; r && key[r] != k; r = nxt[las = r] );
return !!r;
} inline void solve( const int s1, const int s2 ) {
std::vector<int> pos, neg;
rep ( i, 1, half ) {
int f = s1 / pwr[half - i] % 3;
if ( f == 1 ) pos.push_back( i );
else if ( f ) neg.push_back( i );
}
rep ( i, half + 1, n ) {
int f = s2 / pwr[n - i] % 3;
if ( f == 1 ) neg.push_back( i );
else if ( f ) pos.push_back( i );
} assert( pos.size() == neg.size() ); int s = pos.size();
b[1] = 0;
rep ( i, 2, s << 1 ) {
if ( !( i & 1 ) ) {
b[i] = a[pos[( i >> 1 ) - 1]] - b[i - 1];
ans[pos[( i >> 1 ) - 1]] = i - 1;
} else {
b[i] = a[neg[( i >> 1 ) - 1]] - b[i - 1];
ans[neg[( i >> 1 ) - 1]] = i - 1;
}
}
ans[neg[s - 1]] = s << 1;
b[0] = s << 1; rep ( i, 1, n ) if ( !ans[i] ) {
b[++b[0]] = a[i], ans[i] = -b[0];
} puts( "Yes" );
rep ( i, 1, n ) printf( "%lld%c", b[i], i < n ? ' ' : '\n' );
rep ( i, 1, n ) {
if ( ans[i] > 0 ) {
if ( ans[i] < s << 1 ) printf( "%d %d\n", ans[i], ans[i] + 1 );
else printf( "%d 1\n", s << 1 );
} else {
printf( "1 %d\n", -ans[i] );
}
}
} inline void dfs1( const int l, const int r, const int sta, const LL sum ) {
if ( l > r ) return void( get( sum ) = sta );
dfs1( l + 1, r, sta * 3, sum );
dfs1( l + 1, r, sta * 3 + 1, sum + a[l] + INF );
dfs1( l + 1, r, sta * 3 + 2, sum - a[l] - INF );
} inline void dfs2( const int l, const int r, const int sta, const LL sum ) {
if ( l > r ) {
if ( sum && count( -sum ) ) solve( get( sum ), sta ), exit( 0 );
return ;
}
dfs2( l + 1, r, sta * 3, sum );
dfs2( l + 1, r, sta * 3 + 1, sum + a[l] + INF );
dfs2( l + 1, r, sta * 3 + 2, sum - a[l] - INF );
} int main() {
freopen( "problemsetter.in", "r", stdin );
freopen( "problemsetter.out", "w", stdout ); scanf( "%d", &n );
rep ( i, 1, n ) scanf( "%lld", &a[i] ); if ( n == 1 ) {
if ( a[1] % 2 ) puts( "No" );
else printf( "Yes\n%lld\n1 1\n", a[1] / 2 );
return 0;
} rep ( i, 1, n ) if ( !( a[i] % 2 ) ) {
printf( "Yes\n%lld", a[i] / 2 );
rep ( j, 1, n ) if ( i != j ) printf( " %lld", a[j] - ( a[i] / 2 ) );
putchar( '\n' );
rep ( j, 1, n ) {
if ( i == j ) puts( "1 1" );
else printf( "1 %d\n", j + ( j < i ) );
}
return 0;
} half = n + 1 >> 1, pwr[0] = 1;
rep ( i, 1, half ) pwr[i] = pwr[i - 1] * 3; dfs1( 1, half, 0, 0 );
dfs2( half + 1, n, 0, 0 ); puts( "No" );
return 0;
}

Solution -「NOI 模拟赛」出题人的更多相关文章

  1. Solution -「NOI 模拟赛」彩色挂饰

    \(\mathcal{Description}\)   给定一个含 \(n\) 个点 \(m\) 条边的简单无向图,设图中最大点双的大小为 \(s\),则保证 \(s\le6\).你将要用 \(k\) ...

  2. 「CSP-S模拟赛」2019第四场

    「CSP-S模拟赛」2019第四场 T1 「JOI 2014 Final」JOI 徽章 题目 考场思考(正解) T2 「JOI 2015 Final」分蛋糕 2 题目 考场思考(正解) T3 「CQO ...

  3. 「NOIP模拟赛」数位和乘积(dp,高精)

    统计方案数,要么组合数,要么递推(dp)了. 这是有模拟赛历史以来爆炸最狠的一次 T1写了正解,也想到开long long,但是开错了地方然后数组开大了结果100->0 T3看错题本来简单模拟又 ...

  4. 「CSP-S模拟赛」2019第三场

    目录 T1 「POI2007」山峰和山谷 Ridges and Valleys 题目 考场思路(几近正解) 正解 T2 「JOI 2013 Final」 现代豪宅 题目 考场思路(正解) T3 「SC ...

  5. 「CSP-S模拟赛」2019第二场

    目录 T1 Jam的计数法 题目 考场思路(正解) T2 「TJOI / HEOI2016」排序 题目 考场思路(假正解) 正解 T3 「THUWC 2017」随机二分图 题目 考场思路 正解 这场考 ...

  6. 「CSP-S模拟赛」2019第一场

    目录 T1 小奇取石子 题目 考场思路 正解 T2 「CCO 2017」专业网络 题目 考场思路 题解 T3 「ZJOI2017」线段树 题目 考场思路 正解 这场考试感觉很奇怪. \(T1.T2\) ...

  7. 「2018-11-05模拟赛」T5 传送机 解题报告

    5.传送机(sent.*) 问题描述: 黄黄同学要到清华大学上学去了.黄黄同学很喜欢清华大学的校园,每次去上课时总喜欢把校园里面的每条路都走一遍,当然,黄黄同学想每条路也只走一遍. 我们一般人很可能对 ...

  8. 「NOIP模拟赛」Round 3

    Tag 计数+LIS, 二分+ST表, 计数+记搜 A. 改造二叉树 Description 题面 Solution 如果目标序列非严格递增,或者说目标序列是不下降的,那么答案就是 \(n\) 减去最 ...

  9. HHHOJ #153. 「NOI模拟 #2」Kotomi

    抽代的成分远远大于OI的成分 首先把一个点定为原点,然后我们发现如果我们不旋转此时答案就是所有位置的\(\gcd\) 如果要选择怎么办,我们考虑把我们选定的网格边连同方向和大小看做单位向量\(\vec ...

随机推荐

  1. 第10组 Alpha冲刺 (4/6)(组长)

    1.1基本情况 ·队名:今晚不睡觉 ·组长博客:https://www.cnblogs.com/cpandbb/p/13982696.html ·作业博客:https://edu.cnblogs.co ...

  2. Go语言系列之标准库log

    Go语言内置的log包实现了简单的日志服务.本文介绍了标准库log的基本使用. 使用Logger log包定义了Logger类型,该类型提供了一些格式化输出的方法.本包也提供了一个预定义的" ...

  3. JVM完整详解:内存分配+运行原理+回收算法+GC参数等

    不管是BAT面试,还是工作实践中的JVM调优以及参数设置,或者内存溢出检测等,都需要涉及到Java虚拟机的内存模型.内存分配,以及回收算法机制等,这些都是必考.必会技能. JVM内存模型 JVM内存模 ...

  4. C++ 基本类型的大小

    C++的基本类型: char bool (unsigned) short (int) (unsigned) int (unsigned) long (int) (unsigned) long long ...

  5. Servlet Filter(过滤器)

    Servlet Filter 又称 Servlet 过滤器,它是在 Servlet 2.3 规范中定义的,能够对 Servlet 容器传给 Web 资源的 request 对象和 response 对 ...

  6. HttpServletResponse接口详解

    在 Servlet API 中,定义了一个 HttpServletResponse 接口,它继承自 ServletResponse 接口.HttpServletResponse 对象专门用来封装 HT ...

  7. Go 变量及基本数据类型2

    #### Go 变量及基本数据类型(二)今天学习一下基本数据类型,包括整数类型,小数类型,字符类型##### 整数类型用来存放整数数值的, 如0,1,-10,2222等; 整数型的类型有: 类型 有无 ...

  8. javaObject类-equals方法及覆盖

    1 package face_object; 2 /* 3 * Object:所有类的根类. 4 * Object是不断抽取而来的,具备所有对象都具备的共性内容. 5 * 常用的共性功能: 6 * 7 ...

  9. 函数的参数python教程

    一:函数 什么是函数? 函数就类似于工具 提前定义之后可以反复使用 代码冗余 结构清晰 修改繁杂等问题 二:函数的语法结构 def 函数名(参数1,参数2) '''函数注释''' 函数体代码 retu ...

  10. makefile 编译多个目标

    1.静态库libtools.a源码 libtools.h #ifndef tools_h_ #define tools_h_ int sub(int x,int y); int mul(int x,i ...