A. Regular Bracket Sequence

显然,"\(()\)"不影响结果它是自我匹配的,可以把所有的\(((\)和\())\)都放在左边/右边,这样只要检查它们的数目就行,还有个坑点,就是如果\()(\)多于一,需要给左右两边一个负担,必须小于它们的数量才行。

#include <cstdio>
#include <iostream>
using namespace std;
int c1, c2, c3, c4;
int main(){
scanf("%d%d%d%d", &c1, &c2, &c3, &c4);
if(c1 == c4 && c4 >= min(c3, 1)) puts("1");
else puts("0");
return 0;
}

B. Discounts

模拟,从小到大排好序后,答案 \(=\) 总数 - \(a[n - q_i + 1]\)。

#include <cstdio>
#include <iostream>
#include <algorithm>
using namespace std;
const int N = 300010;
typedef long long LL;
int n, m, a[N], q;
LL sum = 0;
int main(){
scanf("%d", &n);
for(int i = 1; i <= n; i++) {
scanf("%d", a + i), sum += a[i];
}
sort(a + 1, a + 1 + n);
scanf("%d", &m);
for(int i = 1; i <= m; i++){
scanf("%d", &q);
printf("%lld\n", sum - a[n - q + 1]);
}
return 0;
}

C. Painting the Fence

考虑到\(q <= 5000\),用前缀和维护每个位置都有几个人刷,然后预处理\([l, r]\)这段有多少\(1\)(他不刷就没人刷)和\(2\)(安排掉他俩就没人刷),用\(O(q ^ 2)\)的复杂度暴力枚举两个人分别是谁,然后\(O(1)\)找即可。

#include <cstdio>
#include <iostream>
#include <cmath>
#include <algorithm>
using namespace std;
typedef pair<int, int> PII;
const int N = 5010;
int n, m, sum[N], c[N], c2[N], tot = 0, ans = -1;
PII a[N];
int main(){
scanf("%d%d", &n, &m);
for(int i = 1; i <= m; i++){
scanf("%d%d", &a[i].first, &a[i].second); }
sort(a + 1, a + 1 + m);
for(int i = 1; i <= m; i++){
sum[a[i].first]++, sum[a[i].second + 1]--;
}
for(int i = 1; i <= n; i++) {
sum[i] += sum[i - 1];
c[i] = c[i - 1] + (sum[i] == 1);
c2[i] = c2[i - 1] + (sum[i] == 2);
tot += (sum[i] > 0);
}
for(int i = 1; i < m; i++){
for(int j = i + 1; j <= m; j++){
int cnt = tot;
int L = a[i].first, R = a[i].second;
int L1 = a[j].first, R1 = a[j].second;
if(L1 <= R) {
cnt -= c[L1 - 1] - c[L - 1];
cnt -= c[max(R, R1)] - c[min(R, R1)];
cnt -= c2[min(R, R1)] - c2[L1 - 1];
}else{
cnt -= c[R] - c[L - 1];
cnt -= c[R1] - c[L1 - 1];
}
ans = max(ans, cnt);
}
}
printf("%d\n", ans);
return 0;
}

F. Clear the String

区间\(dp\)。

设\(f[i][j]\) 为合并\([i, j]\)区间的最小花费,对于任何一个\(f[i][j]\),有三种决策:

  1. 直接多加一位\(min(f[i + 1][j], f[i][j - 1]) + 1\)

  2. 找一个位置\(k(i + 1 <= k <= j )\),使\(str[i] = str[k]\),更新答案为:

\(f[i + 1][k - 1] + f[k][j] + (s[k] != s[i])\)

等于是把\([i + 1, k - 1]\)先合并起来,然后\(i\)字符就会贴到\(k\)一起,然后这两个字符一样,可以视作一个字符,每次修改最坏是用\(k\)为左边界,\(i\)字符作为附庸不用计算花费

  1. 同样的还有用右端点合并...

想状态的时候我也会有疑惑,为什么只用找开头和结尾跟中间匹配呢?重复,每次处理区间时,\(l + 1、l + 2...\)已经找过匹配点了...

后来发现只需要处理用开头字符一种情况,因为两种状态转移上重复了,每次找\(k\)的过程中也相当于\(k\)去找\(i\),在这之前想到于已经匹配过\([l + 1, r], [l + 2, r]...[l + n, r]\),这样的匹配方式是可逆的,先后反复是相同的,即使此时的\(l + n\)左边还没处理,但是每次处理相当于一个包围的形式,可以不重不漏地继承。所以可以不需用步骤\(3\),但是蒟蒻的我肯定想不到啦...

顺便,注意初始化问题,对于\(f[i][j] (i > j)\) 花费是\(0\),当然如果边界写的精准了这种状态不会用到。

#include <cstdio>
#include <iostream>
#include <cstring>
#include <cmath>
using namespace std;
const int N = 510;
int n, f[N][N];
char s[N];
int main(){
scanf("%d%s", &n, s + 1);
for(int i = 1; i <= n; i++) f[i][i] = 1;
for(int l = 2; l <= n; l++){
for(int i = 1, j; (j = i + l - 1) <= n; i++){
f[i][j] = min(f[i + 1][j], f[i][j - 1]) + 1;
for(int k = i; k <= j - 2; k++){
f[i][j] = min(f[i][j], f[i][k] + f[k + 1][j - 1] + (s[k] != s[j]));
}
for(int k = i + 2; k <= j; k++){
f[i][j] = min(f[i][j], f[i + 1][k - 1] + f[k][j] + (s[k] != s[i]));
}
}
}
for(int i = 1; i <= n; i++){
for(int j = 1; j <= n; j++) printf("%d ", f[i][j]);
puts("");
}
printf("%d\n", f[1][n]);
return 0;
}

Codeforces Edu Round 61 A-C + F的更多相关文章

  1. Codeforces Beta Round #61 (Div. 2)

    Codeforces Beta Round #61 (Div. 2) http://codeforces.com/contest/66 A 输入用long double #include<bit ...

  2. Codeforces Beta Round #61 (Div. 2) D. Petya and His Friends 想法

    D. Petya and His Friends time limit per test 2 seconds memory limit per test 256 megabytes input sta ...

  3. Educational Codeforces Round 61

    Educational Codeforces Round 61 今早刚刚说我适合打pikmike出的EDU 然后我就挂了 A 不管 B 不管 C 这道题到快结束了才调出来 大概就是\(n^2\)枚举不 ...

  4. Codeforces Round #485 (Div. 2) F. AND Graph

    Codeforces Round #485 (Div. 2) F. AND Graph 题目连接: http://codeforces.com/contest/987/problem/F Descri ...

  5. Codeforces Round #486 (Div. 3) F. Rain and Umbrellas

    Codeforces Round #486 (Div. 3) F. Rain and Umbrellas 题目连接: http://codeforces.com/group/T0ITBvoeEx/co ...

  6. Codeforces Round #501 (Div. 3) F. Bracket Substring

    题目链接 Codeforces Round #501 (Div. 3) F. Bracket Substring 题解 官方题解 http://codeforces.com/blog/entry/60 ...

  7. Codeforces Round #499 (Div. 1) F. Tree

    Codeforces Round #499 (Div. 1) F. Tree 题目链接 \(\rm CodeForces\):https://codeforces.com/contest/1010/p ...

  8. Codeforces Beta Round #62 题解【ABCD】

    Codeforces Beta Round #62 A Irrational problem 题意 f(x) = x mod p1 mod p2 mod p3 mod p4 问你[a,b]中有多少个数 ...

  9. Codeforces Beta Round #83 (Div. 1 Only)题解【ABCD】

    Codeforces Beta Round #83 (Div. 1 Only) A. Dorm Water Supply 题意 给你一个n点m边的图,保证每个点的入度和出度最多为1 如果这个点入度为0 ...

随机推荐

  1. Socket bind系统调用简要分析

    主要查看linux kernel 源码:Socket.c 以及af_inet.c文件 1.1 bind分析 #include <sys/types.h> /* See NOTES */#i ...

  2. Netlink 内核实现分析 2

    netlink 应用层如何创建socket 应用层通过socket()系统调用创建Netlink套接字,socket系统调用的第一个参数可以是AF_NETLINK或PF_NETLINK(在Linux系 ...

  3. Java入门基础知识点总结(详细篇)

    Java入门基础知识点总结(详细篇)~~~~~目录 1.1 图解 1.1.1 Java基础知识点 1.1.2 Java基础语法的相关内容 1.2 关键字 1.3 标识符 1.3.1 标识符概念 1.3 ...

  4. 怎样禁止Ceph OSD的自动挂载

    前言 本篇来源于群里一个人的问题,有没有办法让ceph的磁盘不自动挂载,一般人的问题都是怎样让ceph能够自动挂载,在centos 7 平台下 ceph jewel版本以后都是有自动挂载的处理的,这个 ...

  5. Python_入门第一篇【持续更新...】

    1.准备 准备电脑 和 分区 1.准备配置稍高的电脑(后后期需要装虚拟机),分辨率1920*1080 2.分区: C→系统 D→Project E→软件安装盘 F→其他 准备编辑器 1.Sublime ...

  6. [代码审计Day2] filter_var函数缺陷代码审计

    简介 // composer require "twig/twig" require 'vendor/autoload.php'; class Template { private ...

  7. 面试必看!凭借着这份 MySQL 高频面试题,我拿到了京东,字节的offer!

    前言 本文主要受众为开发人员,所以不涉及到MySQL的服务部署等操作,且内容较多,大家准备好耐心和瓜子矿泉水. 前一阵系统的学习了一下MySQL,也有一些实际操作经验,偶然看到一篇和MySQL相关的面 ...

  8. 全面解析RayFire的动态对象与静态对象

    我们在日常使用RayFire的过程中,接触得比较多的应该就是RayFire的对象设置了.RayFire的对象包含了动态对象.静态对象与休眠对象,其中动态对象.静态对象可以结合动力学.运动学概念设置动作 ...

  9. 在FL Studio中如何制作和优化你的人声和弦(Vocal Chords)

    人声和弦在Future Bass.Melodic Dubstep等类型的电子音乐中被常用.与一般的和弦相同,其主要起到为主旋律做铺垫的效果,但是人声和弦加入了人声的因素,可以使得和弦更有趣,更有电子音 ...

  10. python应用(3):启用集成开发工具pycharm

    之前写了个python程序给自己用,写代码时用的是macvim(vim的一种),macvim是个编辑工具,由于我已经设置过对python等各种语言的支持特性,所以什么缩进.对齐.高亮之类的表现都有,写 ...