Codeforces Round #579 (Div. 3)

传送门

A. Circle of Students

这题我是直接把正序、逆序的两种放在数组里面直接判断。

Code
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 205;
int q, n;
int a[N], b[N], c[N];
int main() {
ios::sync_with_stdio(false); cin.tie(0);
cin >> q;
while(q--) {
cin >> n;
for(int i = 1; i <= n; i++) cin >> a[i];
int p;
for(int i = 1; i <= n; i++) {
if(a[i] == 1) {
p = i; break;
}
}
for(int i = p; i <= n; i++) {
b[i - p + 1] = a[i];
}
for(int i = 1; i < p; i++) {
b[i + n - p + 1] = a[i];
}
for(int i = p; i >= 1; i--) {
c[p - i + 1] = a[i];
}
for(int i = n; i > p; i--) {
c[n - i + p + 1] = a[i];
}
int ok = 1;
for(int i = 1; i <= n; i++) {
if(b[i] - b[i - 1] != 1) ok = 0;
}
if(ok) {
cout << "YES" << '\n';
continue;
}
ok = 1;
for(int i = 1; i <= n; i++) {
if(c[i] - c[i - 1] != 1) ok = 0;
}
if(ok) {
cout << "YES" << '\n';
continue;
}
cout << "NO" << '\n';
}
return 0;
}

B. Equal Rectangles

排序后判断即可,满足两个条件:对应边长相等;面积乘积相等。

Code
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 1005;
int q, n;
int a[N], b[N];
int main() {
ios::sync_with_stdio(false); cin.tie(0);
cin >> q;
while(q--) {
cin >> n; n <<= 2;
for(int i = 1; i <= n; i++) cin >> a[i];
sort(a + 1, a + n + 1);
int i = 1, j = n;
int ok = 1;
int ans = -1;
while(i < j) {
if(a[i] == a[i + 1] && a[j] == a[j - 1]) {
if(ans == -1) {
ans = a[i] * a[j];
} else {
if(ans != a[i] * a[j]) {
ok = 0; break;
}
}
} else {
ok = 0; break;
}
i += 2; j -= 2;
}
if(ok) cout << "YES" << '\n';
else cout << "NO" << '\n';
}
return 0;
}

C. Common Divisors

水题。

Code
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 4e5 + 5;
int q, n;
ll a[N];
int main() {
ios::sync_with_stdio(false); cin.tie(0);
cin >> n;
for(int i = 1; i <= n; i++) cin >> a[i];
ll g = a[1];
for(int i = 2; i <= n; i++) {
g = __gcd(g, a[i]);
}
int ans = 0;
for(int i = 1; 1ll * i * i <= g; i++) {
if(g % i == 0) {
ans ++;
if(g / i != i) ans++;
}
}
cout << ans;
return 0;
}

D2. Remove the Substring (hard version)

对于串\(t\)中的每个位置,求出其在串\(s\)中最早能出现的位置以及最晚能出现的位置。之后逐一枚举判断即可。

Code
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 2e5 + 5;
char s[N], t[N];
int f[N][26], g[N][26];
int nxt[26];
int h[N][2];
int main() {
ios::sync_with_stdio(false); cin.tie(0);
cin >> s + 1 >> t + 1;
int n = strlen(s + 1), m = strlen(t + 1);
for(int i = n; i >= 0; i--) {
for(int j = 0; j < 26; j++) f[i][j] = nxt[j];
nxt[s[i] - 'a'] = i;
}
for(int i = 0; i < 26; i++) nxt[i] = 0;
for(int i = 1; i <= n + 1; i++) {
for(int j = 0; j < 26; j++) g[i][j] = nxt[j];
nxt[s[i] - 'a'] = i;
}
int now = 0;
for(int i = 1; i <= m; i++) {
h[i][0] = f[now][t[i] - 'a'];
now = f[now][t[i] - 'a'];
}
now = n + 1;
for(int i = m; i >= 1; i--) {
h[i][1] = g[now][t[i] - 'a'];
now = g[now][t[i] - 'a'];
}
int res = max(h[1][1] - 1, n - h[m][0]);
// cout << h[1][1] << '\n';
for(int i = 1; i < m; i++) {
res = max(res, h[i + 1][1] - h[i][0] - 1);
}
cout << res;
return 0;
}

E. Boxers

用个桶来进行标记就行,对于一个数,优先标记其前面的那一个数,其次标记本身,最后标记后面。

因为我们是从小到大枚举,可以证明这样最优。

Code
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 150005;
int q, n;
int a[N], c[N];
bool vis[N];
int main() {
ios::sync_with_stdio(false); cin.tie(0);
cin >> n;
for(int i = 1; i <= n; i++) cin >> a[i];
for(int i = 1; i <= n; i++) c[a[i]]++;
if(c[1] > 1) {
vis[1] = vis[2] = 1;
} else if(c[1] == 1) vis[1] = 1;
for(int i = 2; i < N; i++) {
if(c[i]) {
if(!vis[i - 1]) vis[i - 1] = 1;
else if(!vis[i]) vis[i] = 1;
else vis[i + 1] = 1;
if(c[i] == 2) {
if(!vis[i - 1] && i > 1) vis[i - 1] = 1;
else if(!vis[i]) vis[i] = 1;
else vis[i + 1] = 1;
}
if(c[i] >= 3) {
vis[i] = 1;
vis[i - 1] = 1;
vis[i + 1] = 1;
}
}
}
int ans = 0;
for(int i = 1; i < N; i++) ans += vis[i];
cout << ans;
return 0;
}

F1. Complete the Projects (easy version)

首先考虑把所有\(y>0\)的给搞完,然后对于\(y<0\)的,按照\(x+y\)从大到小排序,再逐一判断就行。

这里从大到小排序可以保证每次能够选得尽量地多,就相当于处理一个\(r->a_i+r\)的逆问题。

Code
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 60005;
int q, n, m, r;
struct node{
int r, v;
}a[N], b[N];
bool vis[N];
int main() {
ios::sync_with_stdio(false); cin.tie(0);
cin >> n >> r;
for(int i = 1; i <= n; i++) {
cin >> a[i].r >> a[i].v;
}
while(1) {
int mx = -N, id;
for(int i = 1; i <= n; i++) {
if(!vis[i] && a[i].r <= r && a[i].v > mx) {
mx = a[i].v; id = i;
}
}
if(mx < 0) break;
vis[id] = 1;
r += mx;
}
int tot = 0;
for(int i = 1; i <= n; i++) {
if(!vis[i]) b[++tot] = a[i];
}
sort(b + 1, b + tot + 1, [&](node a, node b){return a.r + a.v > b.r + b.v;});
int ok = 1;
for(int i = 1; i <= tot; i++) {
if(r >= b[i].r && r + b[i].v >= 0) {
r += b[i].v;
} else ok = 0;
}
if(ok) cout << "YES" << '\n';
else cout << "NO" << '\n';
return 0;
}

F2. Complete the Projects (hard version)

类似于之前的思路,首先贪心地把\(y>0\)的部分尽量取完,然后对于\(y<0\)的\(dp\)来处理。

设\(dp[i][j]\)表示当前\(i\)个物品中选了若干个,\(r\)为\(j\)时取的最大数量,转移时类似于背包。之后可以滚动数组优化一维。

注意一下我们还是要按照\(x+y\)来排序,否则有些状态不能转移到。

Code
#include <bits/stdc++.h>
#define MP make_pair
#define fi first
#define se second
#define INF 0x3f3f3f3f
using namespace std;
typedef long long ll;
typedef pair<int, int> pii;
const int N = 105, MAX = 60005;
int n, r;
pii a[N], b[N];
bool vis[N];
int dp[MAX];
int main() {
ios::sync_with_stdio(false); cin.tie(0);
cin >> n >> r;
for(int i = 1; i <= n; i++) cin >> a[i].fi >> a[i].se;
sort(a + 1, a + n + 1);
int ans = 0;
while(1) {
int mx = -MAX, id = -1;
for(int i = 1; i <= n; i++) {
if(!vis[i] && a[i].fi <= r && a[i].se > mx) {
mx = a[i].se; id = i;
}
}
if(mx < 0) break;
vis[id] = 1;
r += mx; ans++;
}
int tot = 0;
for(int i = 1; i <= n; i++) {
if(a[i].fi <= r && a[i].se < 0) b[++tot] = a[i];
}
sort(b + 1, b + tot + 1, [&](pii a, pii b){
return a.fi + a.se == b.fi + b.se ? a.fi > a.se : a.fi + a.se > b.fi + b.se;
});
// for(int i = 1; i <= tot; i++) cout << b[i].fi << ' ' << b[i].se << '\n';
for(int i = 1; i <= tot; i++) {
for(int j = b[i].fi; j <= r; j++) {
if(j + b[i].se >= 0) dp[j + b[i].se] = max(dp[j + b[i].se], dp[j] + 1);
}
}
int res = 0;
for(int i = 0; i <= r; i++) res = max(res, dp[i]);
ans += res;
cout << ans;
return 0;
}

Codeforces Round #579 (Div. 3)的更多相关文章

  1. 双指针(最大删除子串)Codeforces Round #579 (Div. 3)--Remove the Substring (hard version)

    题目链接:https://codeforces.com/contest/1203/problem/D2 题意: 给你S串.T串,问你最长删除多长的子串使得S串里仍然有T的子序列. 思路: 想了好久,先 ...

  2. Codeforces Round #579 (Div. 3) 套题 题解

    A. Circle of Students      题目:https://codeforces.com/contest/1203/problem/A 题意:一堆人坐成一个环,问能否按逆时针或者顺时针 ...

  3. Codeforces Round #579 (Div. 3) Complete the Projects(贪心、DP)

    http://codeforces.com/contest/1203/problem/F1 Examples input 1 - - output 1 YES input 2 - - output 2 ...

  4. 【cf比赛练习记录】Codeforces Round #579 (Div. 3)

    思考之后再看题解,是与别人灵魂之间的沟通与碰撞 A. Circle of Students 题意 给出n个数,问它们向左或者向右是否都能成一个环.比如样例5是从1开始向左绕了一圈 [3, 2, 1, ...

  5. Codeforces Round #579 (Div. 3) 题解

    比赛链接:https://codeforc.es/contest/1203/ A. Circle of Students 题意:\(T\)组询问,每组询问给出\(n\)个数字,问这\(n\)个数字能否 ...

  6. Codeforces Round #579 (Div. 3)D(字符串,思维)

    #include<bits/stdc++.h>using namespace std;char s[200007],t[200007];int last[200007][27],nxt[2 ...

  7. Codeforces Round #579 (Div. 3) B Equal Rectangles、C. Common Divisors

    B Equal Rectangles 题意: 给你4*n个数,让你判断能不能用这个4*n个数为边凑成n个矩形,使的每个矩形面积相等 题解: 原本是想着用二分来找出来那个最终的面积,但是仔细想一想,那个 ...

  8. Codeforces Round #579 (Div. 3) D2. Remove the Substring (hard version) (思维,贪心)

    题意:给你一个模式串\(t\),现在要在主串\(s\)中删除多个子串,使得得到的\(s\)的子序列依然包含\(t\),问能删除的最长子串长度. 题解:首先,我们不难想到,我们可以选择\(s\)头部到最 ...

  9. Codeforces Round #579 (Div. 3) E. Boxers (贪心)

    题意:给你一组数,每个数都可以进行一次加一减一,问最后最多能有多少不同的数. 题解:我们可以用桶存每个数的次数,然后枚举\([1,150001]\)来求对答案的贡献,然后贪心,这里我们不用担心其他乱七 ...

随机推荐

  1. [THUPC2018]弗雷兹的玩具商店(线段树,背包)

    最近状态有点颓,刷刷水题找找自信. 首先每次询问就是完全背包.可以 $O(m^2)$. 由于每个物品都可以用无数次,所以对于价格相同的物品,我们只用考虑愉悦度最高的. 直接上线段树.$val[i]$ ...

  2. [LeetCode] 683. K Empty Slots K个空槽

    There is a garden with N slots. In each slot, there is a flower. The N flowers will bloom one by one ...

  3. eclipse 设置所有文件编码为UTF-8(最全)

      如何修改eclipse工作空间的字符集以及项目的字符集? 第一种方式:修改eclipse的配置文件 打开{ECLIPSE_HOME}/eclipse.ini文件 在最后一行加上属性: -Dfile ...

  4. 慕课网springboot博客系统开发(一)----spring initializr的使用 gradle构建项目

    spring initializr工具的地址:https://start.spring.io/:通过它可以很方便的创建springboot项目 这里我们选择使用gradle作为项目的构建工具,此spr ...

  5. C#自定义特性的使用

    特性类的使用过程: 第一步:定义一个特性类,定义一些成员来包含验证时需要的数据:第二步:创建特性类实例:创建一个特性类的实例,里面包含着验证某一个属性或者字段需要的数据.将该实例关联到某个属性上面.第 ...

  6. Eclipse JAX-RS (REST Web Services) 2.0 requires Java 1.6 or newer

    pom.xml文件中添加: <build> <plugins> <plugin> <groupId>org.apache.maven.plugins&l ...

  7. Vue双向绑定原理(我尽量写的。简洁)

    先问自己两个问题: 1.app.message修改数据的时候,Vue内部是如何监听message数据发生改变的 使用Object.defineProperty ->监听对象属性的改变 2.当数据 ...

  8. 《 .NET并发编程实战》实战习题集 - 4 - 如何重用一次性资源

    如何重用以下一次性资源代码呢? string text; using (var stream = new StreamReader(path)) { text = stream.ReadToEnd() ...

  9. SpringBoot security关闭验证

    SpringBoot security关闭验证 springboot2.x security关闭验证https://www.cnblogs.com/guanxiaohe/p/11738057.html ...

  10. How to call a stored procedure in EF Core 3.0 via FromSqlRaw(转载)

    问: I recently migrated from EF Core 2.2 to EF Core 3.0. Unfortunately, I haven't found a way to call ...