0%

    有一天,_rqy想出来了一道构造题,出给了wqy去做。然而wqy不会做,于是就来找你。

    你有一个$n$行$m$列的棋盘,其中第$i$行第$j$列的格子标号为$(i,j)$。你需要从$(1,1)$开始遍历这个棋盘。每一次,如果你在$(x,y)$,你可以选择一个向量$(\text{d}x,\text{d}y)$,并且移动到$(x+\text{d}x,y+\text{d}y)$这个格子上。

    你不能离开这个棋盘,同时每一个向量只能使用一次。你的任务是合理安排自己的行走路线,使得每一个格子都只被经过一次。输出这个方案。

    wqy翻译了那么多题面,你一定要帮他解出来!

阅读全文 »

    在$n\times n$的网格上,有若干目标。从最低下扔回旋镖,碰到目标会右转。每行、每列不超过两个目标。现在已知从每一列扔出去会撞到$a_i$个障碍($a_i\le 3$),请求出一种合法方案。

    翻译 by jun头吉吉

阅读全文 »

    给定数据组数 $t$,每组数据包含正整数 $n$、$k$,求满足 $x\geq n$ 的最小正整数 $x$,使 $x$ 是个 $k$-beautiful 数。

    一个正整数是个 $k$-beautiful 数,当且仅当其无前导零的十进制数值表示中,不同的数字不超过 $k$ 个。

    数据满足 $1 \leq t \leq 10^4$,$1 \leq n \leq 10^9$,$1 \leq k \leq 2$。

阅读全文 »

    有 $n$ 个战士站成一排,第 $i$ 个战士的战力是 $a_i$。所有战士的战力都是两两不同的。

    你可以使用两种类型的咒语:

    1. 火球术:你可以消耗 $x$ 点法力值来干掉连续的 $k$ 个战士(你必须干掉正好 $k$ 个,而不能干掉 $\le k$ 个)。

    2. 狂暴术:你可以消耗 $y$ 点法力值,选择站在一起的两个战士使他们展开决斗,战力较弱的那个战士将会被干掉。

    我们来举个例子,假设有 $7$ 个战士,其战力分别为 $[2,3,7,8,11,5,4]$,且此时的$k=3$($k$ 的定义详见火球术)。如果你对战力为 $8$ 与 $11$ 的两个战士施加狂暴术,剩下战士的战力将会变成 $[2,3,7,11,5,4]$(战力为 $8$ 的战士在决斗中战死)。然后如果我们对战力为 $[7,11,5]$ 的战士施加火球术,剩下战士的战力将会变成 $[2,3,4]$。

    你想要组建一支军队,因此你想要将所有战士战力的序列从 $a_1,a_2,\cdots,a_n$ 变为 $b_1,b_2,\cdots,b_m$。试计算你所需的最少法力值。

    输入格式

    第一行两个整数 $n,m (1\le n,m\le 2\cdot 10^5)$ ——序列 $a$ 的长度和序列 $b$ 的长度。

    第二行三个整数 $x,k,y (1\le x,y\le 10^9,1\le k\le n)$ ——火球术消耗的法力值,火球术的范围和狂暴术消耗的法力值。

    第三行 $n$ 个整数 $a_1,a_2,…,a_n (1\le a_i\le n)$。保证 $a_i$ 是两两不同的。

    第四行 $m$ 个整数 $b_1,b_2,…,b_m(1\le b_i\le n)$。保证 $b_i$ 是两两不同的。

    输出格式

    一行一个整数,即将序列从 $a_1,a_2,\cdots,a_n$ 变为 $b_1,b_2,\cdots,b_m$所需的最少法力值。如果无法完成变换,则输出$-1$。

阅读全文 »

    有一个无限图,其中有无数个节点,从 $1$ 开始标号。有一条从 $u$ 到 $u+v$ 的单向边,当且仅当 $u \& v = v$ (这里的 $\&$ 指 按位与 。除此以外没有其它边。

    有 $q$ 个询问,询问是否存在一条从 $u$ 到 $v$ 的路径。

    输入格式

    第一行一个整数 $q$ ($1\le q\le10^5 $) —— 询问的个数

    接下来 $q$ 行中,每行有两个整数 $u,v$ ($1 \leq u,v < 2^{30}$),意义如上

    输出格式

    对于每个询问,输出一行 YES 来表示存在从 $u$ 到 $v$ 的一条路径,或输出一行 NO 表示不存在这样一条路径。(你可以以任意大小写形式来输出 YESNO)

阅读全文 »

    给定一张 $n$ 行 $m$ 列的黑白图片(下标从 $1$ 开始),每一个单元格都被涂上了黑色或白色($1$ 或者 $0$)。

    我们对这张图片进行了若干次(可能为零次)操作,每一次操作都是下列两种之一:

    • 选择一个单元格,这个单元格不能在图片的边缘(即,单元格所在行不能是 $1$ 或 $n$ 行,所在列不能是 $1$ 或 $m$ 列),并且这个单元格被四个不同颜色的单元格包围(中间 $0$ 四周 $1$,反之亦然),将这个单元格涂成相反的颜色;

    • 复制一份当前图片。

    两种操作不一定会交替进行。

    给出你初始图片与 $k$ 份复制图片,一共 $k+1$ 份图片,这 $k+1$ 份图片是被随机打乱的。

    你的任务是恢复操作的顺序。若有多种可能答案,只输出其中一个即可。

    所有数据保证答案一定存在。

    输入格式

    输入第一行包含三个整数 $n$、$m$ 以及 $k$($3\le n,m\le 30$;$0\le k\le 100$),分别表示图片的行数、列数和复制图片的数量。

    接下来 $k+1$ 行,每行一张图片,包括 $k$ 张复制图片和 $1$ 张初始图片,顺序是打乱的。

    每张图片由 $n$ 行 $m$ 列组成,每个单元格都为 $0$ 或 $1$。每张图片之前都有一个空行。

    输出格式

    输出第一行一个整数,表示初始图片是第几张。图片按其输入顺序分别编号 $1$ 至 $k+1$。

    输出第二行一个整数 $q$,表示进行了多少次操作。

    接下来 $q$ 行,每行对应一次操作,须按正确顺序输出操作。每个操作有题目描述中提到的两种类型:

    • $1\ x\ y$ 表示在坐标 $(x,y)$ 执行第一种操作;

    • $2\ i$ 表示复制一份当前图片,编号是 $i$。

阅读全文 »

    Alice做到了这样一道题:

    > 给定一个序列$a$,有$n$个元素,编号从$0$到$n-1$。求$\max\limits_{0 \leq l \leq r \leq n-1} \sum\limits_{l \leq i \leq r} (r-l+1) \cdot a_i$。

    >

    > $|a_i| \leq 10^6,n \leq 2000$

    Alice觉得这题太水了,很快就给出了解法:

    ```

    function find_answer(n, a)

    # Assumes n is an integer between 1 and 2000, inclusive# Assumes a is a list containing n integers: a[0], a[1], ..., a[n-1]res = 0cur = 0k = -1for i = 0 to i = n-1    cur = cur + a[i]    if cur &lt; 0        cur = 0        k = i    res = max(res, (i-k)*cur)return res

    ```

    聪明的你一定发现了,Alice的解法是错误的。例如对于序列$a = [6, -8, 7, -42]$,Alice的程序得出的结果是$7$,而正确答案应该是$3 \cdot (6-8+7) = 15$。

    于是你决定HACK掉Alice的解法。

    请给出一组数据,使得正确答案-Alice的答案=$k$,你的数据必须满足$n \leq 2000,|a_i| \leq 10^6$。

    $k \leq 10^9$

阅读全文 »