比赛链接:https://codeforces.com/contest/1400

A. String Similarity

题意

给出一个长 $2n-1$ 的二进制串 $s$,构造一个长 $n$ 的字符串,使其与 $s$ 的每个长 $n$ 的子串至少有一处字母相等。

题解

长 $n$ 的子串恰有 $n$ 个,每个子串取一位即可。

代码

#include <bits/stdc++.h>
using namespace std; void solve() {
int n;
string s;
cin >> n >> s;
for (int i = 0; i < int(s.size()); i += 2)
cout << s[i];
cout << "\n";
} int main() {
int t;
cin >> t;
while (t--) solve();
}

B. RPG Protagonist

题意

有两个容积分别为 $p,f$ 的背包和两种物品:

  • 一种有 $cnt_s$ 个,每个体积为 $s$
  • 一种有 $cnt_w$ 个,每个体积为 $w$

问最多能装多少个物品。

题解

优先装体积较小的一种物品,然后枚举第一个背包所装的数量。

代码

#include <bits/stdc++.h>
using namespace std; void solve() {
int p, f;
cin >> p >> f;
int cnt_s, cnt_w;
cin >> cnt_s >> cnt_w;
int s, w;
cin >> s >> w;
if (s > w) {
swap(cnt_s, cnt_w);
swap(s, w);
}
auto func = [](int& cap, int wt, int &cnt) {
int mi = min(cnt, cap / wt);
cap -= mi * wt;
cnt -= mi;
return mi;
};
int ans = 0;
const int N = min(cnt_s, p / s);
for (int i = 0; i <= N; i++) {
int res = i;
int caps = p - i * s, capw = f;
int ns = cnt_s - i, nw = cnt_w;
res += func(caps, w, nw);
res += func(capw, s, ns);
res += func(capw, w, nw);
ans = max(ans, res);
}
cout << ans << "\n";
} int main() {
int t;
cin >> t;
while (t--) solve();
}

C. Binary String Reconstruction

题意

一个二进制串 $s$ 的衍生串 $t$ 按如下规则构造:

  • 如果 $s_{i-x}=1$ 或 $s_{i+x}=1$,$t_i=1$
  • 否则 $t_i=0$

给出 $t$ 和 $x$,试还原 $s$ 。

题解

根据 $t_i=0$ 确定 $s$ 中的 $0$,其余位置均为 $1$ 。

然后判断构造出的 $s$ 是否与 $t$ 矛盾即可。

代码

#include <bits/stdc++.h>
using namespace std; void solve() {
string s;
cin >> s;
int x;
cin >> x;
const int N = s.size();
string ans(N, '1');
for (int i = 0; i < N; i++) {
if (s[i] == '0') {
if (i - x >= 0) ans[i - x] = '0';
if (i + x < N) ans[i + x] = '0';
}
}
bool ok = true;
for (int i = 0; i < N; i++) {
if (s[i] == '1') {
if (i - x >= 0 and ans[i - x] == '1') continue;
if (i + x < N and ans[i + x] == '1') continue;
ok = false;
}
}
cout << (ok ? ans : "-1") << "\n";
} int main() {
int t;
cin >> t;
while (t--) solve();
}

D. Zigzags

题意

给出一个大小为 $n$ 的数组 $a$,找出满足:

  • $1 \le i < j < k < l \le n$
  • $a_i=a_k$ and $a_j=a_l$

的四元组 $(i,j,k,l)$ 的数目。

题解

移项得:$(a_i,a_j)=(a_k,a_l)$ 。

即计算数组中相同的二元组的数目。

Tips

因为 $n^2$ 将近 $10^7$,所以使用 map 的 $O(n^2log_n)$ 会超时,可以用二维散列代替。

代码

#include <bits/stdc++.h>
using namespace std; void solve() {
int n;
cin >> n;
vector<int> a(n);
for (int i = 0; i < n; i++) {
cin >> a[i];
--a[i];
}
long long ans = 0;
vector<int> cnt(n * n);
for (int j = 0; j < n; j++) {
for (int i = j - 1; i >= 0; i--) {
++cnt[a[i] * n + a[j]];
}
int k = j + 1;
for (int l = k + 1; l < n; l++)
ans += cnt[a[k] * n + a[l]];
}
cout << ans << "\n";
} int main() {
int t;
cin >> t;
while (t--) solve();
}

Educational Codeforces Round 94 (Rated for Div. 2)【ABCD】的更多相关文章

  1. Educational Codeforces Round 97 (Rated for Div. 2)【ABCD】

    比赛链接:https://codeforces.com/contest/1437 A. Marketing Scheme 题解 令 \(l = \frac{a}{2}\),那么如果 \(r < ...

  2. Educational Codeforces Round 94 (Rated for Div. 2) String Similarity、RPG Protagonist、Binary String Reconstruction、Zigzags 思维

    题目链接:String Similarity 题意: 首先题目定义了两个串的相似(串的构成是0.1),如果两个串存在对于一个下标k,它们的值一样,那么这两个串就相似 然后题目给你一个长度为2n-1的串 ...

  3. Educational Codeforces Round 94 (Rated for Div. 2) D. Zigzags (枚举,前缀和)

    题意:有一长度为\(n(4\le n\le 3000)\)的数组,选择四个位置\((i,j,k,l)\ (1\le i<j<k\le n)\),使得\(a_i=a_k\)并且\(a_j=a ...

  4. Educational Codeforces Round 94 (Rated for Div. 2) C. Binary String Reconstruction (构造)

    题意:给你一个字符串\(s\),原字符串为\(w\),如果\(i>x\)且\(w_{i-x}=1\),那么\(s_{i}=1\),如果\(i+x\le n\)且\(w_{i+x}=1\),那么\ ...

  5. Educational Codeforces Round 94 (Rated for Div. 2) B. RPG Protagonist (数学)

    题意:你和你的随从去偷剑和战斧,你可以最多可以拿\(p\)重的东西,随从可以拿\(f\)重的东西,总共有\(cnt_{s}\)把剑,\(cnt_{w}\)把战斧,每把剑重\(s\),战斧重\(w\), ...

  6. Educational Codeforces Round 94 (Rated for Div. 2) A. String Similarity (构造水题)

    题意:给你一个长度为\(2*n-1\)的字符串\(s\),让你构造一个长度为\(n\)的字符串,使得构造的字符串中有相同位置的字符等于\(s[1..n],s[2..n+1],...,s[n,2n-1] ...

  7. Educational Codeforces Round 74 (Rated for Div. 2)【A,B,C【贪心】,D【正难则反的思想】】

    A. Prime Subtractiontime limit per test2 secondsmemory limit per test256 megabytesinputstandard inpu ...

  8. Educational Codeforces Round 60 (Rated for Div. 2) - C. Magic Ship

    Problem   Educational Codeforces Round 60 (Rated for Div. 2) - C. Magic Ship Time Limit: 2000 mSec P ...

  9. Educational Codeforces Round 60 (Rated for Div. 2) - D. Magic Gems(动态规划+矩阵快速幂)

    Problem   Educational Codeforces Round 60 (Rated for Div. 2) - D. Magic Gems Time Limit: 3000 mSec P ...

随机推荐

  1. [leetcode] 周赛 223

    比赛题目:https://leetcode-cn.com/contest/weekly-contest-223/. 解码异或后的数组 题目:1720. 解码异或后的数组. 还记得数列求和的「累加法」? ...

  2. 支持向量机(SVM)原理详解

    SVM简介 支持向量机(support vector machines, SVM)是一种二分类模型,它的基本模型是定义在特征空间上的间隔最大的线性分类器,间隔最大使它有别于感知机:SVM还包括核技巧, ...

  3. python_字典(dict)

    dict 一.结构: info = { "key":"value", "key":"value" } print(inf ...

  4. ctfhub技能树—文件上传—00截断

    什么是00截断 相关教程:http://www.admintony.com/%E5%85%B3%E4%BA%8E%E4%B8%8A%E4%BC%A0%E4%B8%AD%E7%9A%8400%E6%88 ...

  5. Java入门者:如何写出美观的Java代码?

    前言 在帮助各位同学远程解决代码问题的时候,发现很多同学的代码都有一个共同问题:代码书写格式不规范.虽然代码书写规范对程序性能及运行并不影响,但影响着别人对你编程习惯或能力的第一印象,同时也会给阅读者 ...

  6. FLask的偏函数应用

    偏函数 实际上,偏函数主要辅助原函数,作用其实和原函数差不多,不同的是,我们要多次调用原函数的时候,有些参数,我们需要多次手动的去提供值.而偏函数便可简化这些操作,减少函数调用,主要是将一个或多个参数 ...

  7. 前端面试准备笔记之JavaScript(01)

    1.1 typeof 能判断哪些类型? typeof可以识别所有的值类型 typeof可以识别函数 //function typeof可以判断是否是引用类型(不可以再细分) //object 1.2 ...

  8. day132:2RenMJ:MJ需求文档&MJ游戏流程&Egret白鹭引擎安装&TypeScript简要介绍

    目录 1.麻将产品需求文档 2.麻将游戏流程 3.Egret白鹭引擎 4.TypeScript简要了解 5.TypeScript快速入门 1.麻将产品需求文档 1.麻将术语 1.名词术语 牌⼦: 序数 ...

  9. I/O 复用 multiplexing data race 同步 coroutine 协程

    小结: 1.A file descriptor is considered ready if it is possible to perform the corresponding I/O opera ...

  10. Linux 中的文件属性

    文件属性 d 开头是: 目录文件.l  开头是: 符号链接(指向另一个文件,类似于瘟下的快捷方式).s 开头是: 套接字文件(sock).b 开头是: 块设备文件,二进制文件.c 开头是: 字符设备文 ...