Codeforces Round #104 (Div. 1)
A.Lucky Conversion
题意
- 给定两个长度为 \(N(N \le 10^5)\) 且由4和7构成的 \(a, b\)串
- 对 \(a\) 可以有两种操作:
- 交换两个位置的字符;
- 改变一个位置的字符。
- 求最少到操作次数,使得两串相同。
思路
- 统计需要改变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)\) 次操作:
- switch l r:将区间 \([l, r]\) 的 \(4 \to 7, 7 \to 4\) 。
- count:求串s的最长上升子序列。
思路
- 将4看成0, 7看成1
- 线段树维护区间0的个数 \(c_0\), 1的个数 \(c_1\), 最长上升子序列长度 \(lis\), 下降 \(lds\)。
Codeforces Round #104 (Div. 1)的更多相关文章
- Codeforces Round #456 (Div. 2)
Codeforces Round #456 (Div. 2) A. Tricky Alchemy 题目描述:要制作三种球:黄.绿.蓝,一个黄球需要两个黄色水晶,一个绿球需要一个黄色水晶和一个蓝色水晶, ...
- 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 ...
- Codeforces Round #354 (Div. 2) ABCD
Codeforces Round #354 (Div. 2) Problems # Name A Nicholas and Permutation standard input/out ...
- Codeforces Round #368 (Div. 2)
直达–>Codeforces Round #368 (Div. 2) A Brain’s Photos 给你一个NxM的矩阵,一个字母代表一种颜色,如果有”C”,”M”,”Y”三种中任意一种就输 ...
- cf之路,1,Codeforces Round #345 (Div. 2)
cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅..... ...
- Codeforces Round #279 (Div. 2) ABCDE
Codeforces Round #279 (Div. 2) 做得我都变绿了! Problems # Name A Team Olympiad standard input/outpu ...
- 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 ...
- 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 ...
- Codeforces Round #371 (Div. 1)
A: 题目大意: 在一个multiset中要求支持3种操作: 1.增加一个数 2.删去一个数 3.给出一个01序列,问multiset中有多少这样的数,把它的十进制表示中的奇数改成1,偶数改成0后和给 ...
随机推荐
- Java并发编程(二)线程任务的中断(interrupt)
使用interrupt()中断线程 当一个线程运行时,另一个线程可以调用对应的Thread对象的interrupt()方法来中断它,该方法只是在目标线程中设置一个标志,表示它已经被中断,并立即返回. ...
- Rhel7的基本使用
1.修改主机名 [root@localhost ~]# cat /etc/hostname localhost.localdomain[root@localhost ~]# hostnamectl s ...
- Android 自带图标库 android.R.drawable
在xml文件中调用. android:title="@string/secure_connect"android:orderInCategory="100"an ...
- linux下获取帮助
-h --help man 代號 代表內容 使用者在shell中可以操作的指令或可执行档 系統核心可呼叫的函数与工具等 一些常用的函数(function)与函数库(library),大部分是C的函数库 ...
- Android之View.onMeasure方法
View在屏幕上显示出来要先经过measure(计算)和layout(布局). 1.什么时候调用onMeasure方法? 当控件的父元素正要放置该控件时调用.父元素会问子控件一个问题,“你想要用多大地 ...
- Javascript 基础--JS函数(三)
一.基本概念:未完成某一个功能的代码(语句,指令)的集合. 二.函数的调用方式: 2.1.函数名(传递参数1,传递参数2) 基本语法 function 函数名(参数列表){ //代码; retur ...
- jsonObject jsonArray jsonTokener jsonStringer,json解析以及http请求获取josn数据并加以解析
JSON的定义: 一 种轻量级的数据交换格式,具有良好的可读和便于快速编写的特性.业内主流技术为其提供了完整的解决方案(有点类似于正则表达式 ,获得了当今大部分语言的 支持),从而可以在不同平台间进行 ...
- Stm32_调试出现 Error:Flash Download Failed-"Cortex-M3"
rror:Flash Download Failed-"Cortex-M3"出现一般有两种情况: 1.SWD模式下,Debug菜单中,Reset菜单选项(Autodetect/HW ...
- php大力力 [025节] 来不及学习和分类的,大力力认为有价值的一些技术文章合集(大力力二叔公)(2015-08-27)
php大力力 [025节] 来不及学习和分类的,大力力认为有价值的一些技术文章合集(大力力二叔公)(2015-08-27) 比较好的模版 免费模板网,提供大量DIV+CSS布局网页模板下载及后台管理 ...
- vijos 1776 关押罪犯
带权并查集+贪心. #include<iostream> #include<cstdio> #include<cstring> #include<algori ...