A.Lucky Conversion

题意

  • 给定两个长度为 \(N(N \le 10^5)\) 且由4和7构成的 \(a, b\)串
  • 对 \(a\) 可以有两种操作:
  1. 交换两个位置的字符;
  2. 改变一个位置的字符。
  • 求最少到操作次数,使得两串相同。

思路

  • 统计需要改变4的个数和改变7的个数。
  • 两个数到最小值表示两两交换使得对应位相同,剩下的只有其中一种,再进行操作2使得对应位相同。
  • 也就是取两者最大值即答案。

B. Lucky Number 2

题意

  • 用 \(cnt(x)\) 表示串 \(x\) 在一个串 \(s\) 中出现到次数。
  • 现给出 \(cnt(4), cnt(7), cnt(47), cnt(74)\),求满足这些条件的最小的串 \(s\),串 \(s\) 仅包含4和7。

思路

  • 47和74只出现在4、7交界处,即如果我们把连续的4和连续的7看成4和7,则最后的串到形式为4、7交替出现,例如……47474……。
  • 显然,47和74的个数差值不会超过1。
  • 那么只要根据47和74的3种差值构造,多余的4插到前面,7则放到后面。

C. Lucky Subsequence

题意

  • 给定 \(N(N \le 10^5)\) 个数 \(a_i(1 \le a_i \le 10^9)\) ,其中仅由4、7构成的数是幸运数。
  • 求出长度为 \(K\) 的子序列,满足序列中没有相同的幸运数的方案数,结果对 \(10^9 + 7\) 取模。
  • 只要序列选取到位置不同,则认为两种方案不同。

思路

  • 在 \(10^9\) 范围内幸运数的个数就1000个左右。
  • 用 \(f(i,j)\) 表示前 \(i\) 种幸运数中取 \(j\) 种放入集合中的权值积之和,转移: \[f(i,j) = f(i - 1, j) + c_i f(i - 1, j - 1) \] \(c_i\) 表示第 \(i\)种幸运数出现的次数。
  • 假设取了 \(j\) 个幸运数,则从非幸运数集合中取 \(K - j\) 个放入集合即可。

D. Lucky Pair

题意

  • 给一个长为 \(N(N \le 10^5)\) 的序列。
  • 其中幸运数的个数不超过 \(10^3\) 。
  • 求 \([l_1,r_1]\) 和 \([l_2, r_2]\) 的对数,满足 \(l_1 \le r_1 \lt l_2 \le r_2\),且两个区间没有幸运数的交集,就是对于每种幸运数最多只能出现在一个区间中。

思路

  • 可以用总方案数 \(-\) 不合法的方案数。
  • 总方案数 = \(\binom{N}{4} + 2\binom{N}{3} + \binom{N}{2}\)
  • 假设已经得到了左区间 \([l_1, r_1]\) ,那么右半部分 \((r_1, n]\) 会被lucky number分割成若干的区间,使得这些小区间不包含lucky number。
  • 先固定左区间的右端点 \(r_1\),然后从大到小枚举左端点 \(l_1\) ,右半部分 \((r_1, n]\) 区间会发生变化,当且仅当 \(l_1\) 是lucky number并且在 \((l_1, r_1]\) 未出现,所以我们只要枚举lucky number的位置即可。
  • 考虑右半部分新增的分割点,假设为 \(p\) ,\(pre\)表示 \(p\) 的前一个分割点,\(nxt\)为后一个。那么新增的不合法右区间为包含 \(p\) 的且不包含\(pre,nxt\)的区间。
  • 由于有非lucky number的存在,所以还要考虑左右端点不是lucky number的扩展。

E. Lucky Queries

题意

  • 给一个长为 \(N(N \le 10^6)\) 且由4、7构成的串 \(s\) 。
  • 有 \(M(M \le 3 \times 10^5)\) 次操作:
  1. switch l r:将区间 \([l, r]\) 的 \(4 \to 7, 7 \to 4\) 。
  2. count:求串s的最长上升子序列。

思路

  • 将4看成0, 7看成1
  • 线段树维护区间0的个数 \(c_0\), 1的个数 \(c_1\), 最长上升子序列长度 \(lis\), 下降 \(lds\)。

Codeforces Round #104 (Div. 1)的更多相关文章

  1. Codeforces Round #456 (Div. 2)

    Codeforces Round #456 (Div. 2) A. Tricky Alchemy 题目描述:要制作三种球:黄.绿.蓝,一个黄球需要两个黄色水晶,一个绿球需要一个黄色水晶和一个蓝色水晶, ...

  2. Codeforces Round #366 (Div. 2) ABC

    Codeforces Round #366 (Div. 2) A I hate that I love that I hate it水题 #I hate that I love that I hate ...

  3. Codeforces Round #354 (Div. 2) ABCD

    Codeforces Round #354 (Div. 2) Problems     # Name     A Nicholas and Permutation standard input/out ...

  4. Codeforces Round #368 (Div. 2)

    直达–>Codeforces Round #368 (Div. 2) A Brain’s Photos 给你一个NxM的矩阵,一个字母代表一种颜色,如果有”C”,”M”,”Y”三种中任意一种就输 ...

  5. cf之路,1,Codeforces Round #345 (Div. 2)

     cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅.....   ...

  6. Codeforces Round #279 (Div. 2) ABCDE

    Codeforces Round #279 (Div. 2) 做得我都变绿了! Problems     # Name     A Team Olympiad standard input/outpu ...

  7. Codeforces Round #262 (Div. 2) 1003

    Codeforces Round #262 (Div. 2) 1003 C. Present time limit per test 2 seconds memory limit per test 2 ...

  8. Codeforces Round #262 (Div. 2) 1004

    Codeforces Round #262 (Div. 2) 1004 D. Little Victor and Set time limit per test 1 second memory lim ...

  9. Codeforces Round #371 (Div. 1)

    A: 题目大意: 在一个multiset中要求支持3种操作: 1.增加一个数 2.删去一个数 3.给出一个01序列,问multiset中有多少这样的数,把它的十进制表示中的奇数改成1,偶数改成0后和给 ...

随机推荐

  1. UITableViewCell 单元格样式

    UITableViewCell 单元格样式作用 typedef NS_ENUM(NSInteger, UITableViewCellStyle) { UITableViewCellStyleDefau ...

  2. [转]diskpart命令

    from: http://support.microsoft.com/kb/300415/zh-cn Diskpart 与许多命令行实用工具不同,原因是它不以单行模式操作.相反,当您启动该实用工具后, ...

  3. Maven 建立web项目 The import javax.servlet cannot be resolved

    右击项目,选择Java Build Path->Libraries->Add External JARs,tomcat的路径lib文件夹下选中"servlet-api.jar&q ...

  4. poj1845 数论

    //Accepted 204K 16MS //约数和 //n=p1^e1*p2^e2***pk^ek //约数和为:(p1^0+p1^1+..+p1^e1)*(p2^0+p2^1+..+p2^e2)* ...

  5. CAD系统变量(参数)大全

    所谓系统变量就是一些参数,这些参数有些是可以在“选项”或其他对话框中进行设置的,有些这必须通过在命令行输入变量名进行设置,当然对于高手来说,还可以通过二次开发程序来进行控制. CAD有很多的变量,例如 ...

  6. 学会使用Ogitor

    这几天在用Ogre读取Ogitor的场景,遇到了不少问题,在网上也找不到详细的说明,虽然读取Ogitor的场景对很多人来说太简单了,但对一些新手来说就有点难了,我刚开始就觉得是无从下手,因此简单的描述 ...

  7. SQL Server 按某一字段分组 取 最大 (小)值所在行的数据

    SQL Server 按某一字段分组 取 最大 (小)值所在行的数据 -- 按某一字段分组 取 最大 (小)值所在行的数据 -- (爱新觉罗.毓华(十八年风雨,守得冰山雪莲花开) 2007-10-23 ...

  8. Oracle排序问题

    关于oracle排序的几点认识: (1)oracle本身不具有任何默认排序功能,要想排序,必须使用order by,而order by后的数据行默认是asc(升序排列),要降序选择desc : (2) ...

  9. UID 修改 & UID 锁死修复

    首先是UID修改的问题,只要卡是UID卡,就都可以修改UID,首先读卡器连接电脑,卡片放到读卡器上. 然后我们要用一个工具,UID207.打开UID207.exe,点Initialize,初始化. 然 ...

  10. iOS interface guidelines (界面设计指南)<一>

    一.      为iOS而设计 1.iOS体现的主题: (1)Deference(顺从):UI的存在就是为了让顾客更加容易理解和进行交互,而不是要和顾客玩智力游戏 (2)Clarity(清晰):在每个 ...