Codeforces Round #481 (Div. 3) 经典几道思维题
A - AAA
给你一颗树,支持两种操作
1.修改某一节点的权值
2.查询子树的权值(子树中节点的个数)
很显然可以用树状数组/线段树维护
B - BBB
存一下出现次数即可
int a[100], st[1100];
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
int n;
cin >> n;
int cnt = 0;
for (int i = 1; i <= n; ++i) {
cin >> a[i];
st[a[i]] += 1;
}
for (int i = 1; i <= 1000; ++i) if (st[i]) cnt += 1;
cout << cnt << "\n";
int ccnt = 0;
for (int i = 1; i <= n; ++i) {
if (st[a[i]] == 1) {
cout << a[i];
ccnt += 1;
if (ccnt != cnt)cout << " ";
} else st[a[i]] -= 1;
}
}
C - CCC
两种做法,写前缀和 + 二分就找到楼层序号位置
const int N = 2e5 + 10;
ll a[N], s[N];
int n, m;
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
cin >> n >> m;
for (int i = 1; i <= n; ++i) cin >> a[i], s[i] = s[i - 1] + a[i];
while (m--) {
ll t; cin >> t;
int l = 1, r = n, cnt = 0;
while (l <= r) {
int mid = (l + r) / 2;
if (s[mid] < t) l = mid + 1, cnt = mid;
else r = mid - 1;
}
cout << cnt + 1 << " " << t - s[cnt] << "\n";
}
}
D - DDD
题意:
给你一组数,然后给你三种操作,分别是+1,-1,不变,然后判断能否通过操作将这组数变成等差数列,若能则输出最小改变次数,若不行则输出-1。
思路:
乍一看题,以为是DFS的题,使劲想怎么搜,后来搜超时了555。下面说正解,其实根据等差数列的性质,只需要处理前两项枚举所有可能结果,暴力找出最小次数即可。
const int N = 1e5 + 10, inf = 0x3f3f3f3f;
ll a[N], b[N];
int n;
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
cin >> n;
for (int i = 0; i < n; ++i) cin >> a[i];
int cnt = inf;
for (int i = -1; i <= 1; ++i)
for (int j = -1; j <= 1; ++j) {
b[0] = a[0] + i;
b[1] = a[1] + j;
int d = b[1] - b[0];
bool f = false;
int t = abs(i) + abs(j);
for (int r = 2; r < n; ++r) {
b[r] = b[r - 1] + d;
if (abs(b[r] - a[r]) > 1) {f = true; break;}
else {
if (b[r] != a[r]) t += 1;
}
}
if (!f) cnt = min(cnt, t);
}
if (cnt == inf) cout << "-1\n";
else cout << cnt << "\n";
}
E - EEE
题意:
给你一个含有n个整数的数组,每一个数a[i]代表汽车在站i时,车上增多了a[i]个人,如果a[i]为负,代表减少了人数。
并告诉你这个汽车的最大承载力为w个人,
请你判断初始时汽车上有多少个人,才满足整个数组的情况,。
如果某一个情况,车上的人数为负,或者人数大于w,那么说明这个数组时不合理的,。这时请输出0
思路:
可以抽象为,求这个数组的前缀和数组中的最大值和最小值,。只要最大值不大于容量,再判断下最低值的绝对值不大于容量。就可以说明是合理的。
然后可以的方案数中初始的人数一定是连续的,那么这些人数中的最大值是 \(min(w-maxsum,w)\) ,即不让过程中容量大于 \(w\) 的最大值。
最小值是 \(max(0,-1*minsum)\),然后最大值减去最小值 \(+1\) 就是答案了。
const int N = 1e3 + 10;
ll a[N], s[N];
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
ll n, m; cin >> n >> m;
ll sum = 0, Max = 0, Min = 0;
for (int i = 1; i <= n; ++i) {
cin >> a[i];
sum += a[i];
Max = max(sum, Max);
Min = min(sum, Min);
}
if (Min < 0) Min = llabs(Min);
sum = m - Max - Min + 1;
if (sum < 0) cout << 0 << "\n";
else cout << sum << "\n";
}
F - FFF
题意:
给定 \(n\) 个人员skill值,并给出 \(k\) 个有矛盾的对,对于每个人,可以做skill值比自己小且没有矛盾人的导师。输出每一个人可做多少人的导师。
思路:
- 排序后对每个人的skill值二分查找,存储到ans[]中。
- 对于每个矛盾对,skill值大的ans减1即可。
const int N = 2e5 + 10;
ll a[N], b[N], c[N];
int n, m;
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
cin >> n >> m;
for (int i = 1; i <= n; ++i) cin >> a[i], b[i] = a[i];
while (m--) {
int x, y;
cin >> x >> y;
if (a[x] > a[y]) c[x] += 1;
else c[y] += 1;
}
sort(b + 1, b + 1 + n);
for (int i = 1; i <= n; ++i) {
int t = lower_bound(b + 1, b + 1 + n, a[i]) - b - 1;
cout << t - c[i] << " ";
}
}
G - GGG
题意:
给你N天,和M个考试,
每一个考试有三个参数。
s是考试可以开始准备的日期。
e是考试日期(这一天必须考试,不能准备)
v,这个考试需要多少天。
每一天最多只能做一件事,要么这一天休息,要么准备考试,要么参加考试。
每一个考试必须在考试之前严格的准备了v天才能通过。
请你确定你是否能能过这M个考试,
如果不可以,只需要输出-1
否则输出每一天i是做什么事情,休息是0,考试是m+1,准备是准备的那个考试编号。
思路:
贪心题,
按照每一个考试的考试日期由近到远排序。
然后枚举每一个天,1~n
如果这一天没有被使用,去检查最近1~m哪一个考试在第 i 天准备。
如果可以填就填,这样贪心搞。
const int N = 1e2 + 10;
struct node {int s, d, c, id;} p[N];
int n, m, Day[N];
bool cmp(node a, node b) {return a.d < b.d;}
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
cin >> n >> m;
for (int i = 1; i <= m; ++i) {
cin >> p[i].s >> p[i].d >> p[i].c;
p[i].id = i;
Day[p[i].d] = m + 1;
}
sort(p + 1, p + 1 + m, cmp);
for (int i = 1; i <= m; ++i) {
int day = 0;
for (int j = p[i].s; j <= n; ++j) {
if (Day[j] == 0) day += 1, Day[j] = p[i].id;
if (day == p[i].c) break;
if (j >= p[i].d) {
cout << -1 << "\n";
return 0;
}
}
}
for (int i = 1; i <= n; ++i) cout << Day[i] << " \n"[i == n];
}
Codeforces Round #481 (Div. 3) 经典几道思维题的更多相关文章
- Codeforces Round #353 (Div. 2) C. Money Transfers (思维题)
题目链接:http://codeforces.com/contest/675/problem/C 给你n个bank,1~n形成一个环,每个bank有一个值,但是保证所有值的和为0.有一个操作是每个相邻 ...
- Codeforces Round #380 (Div. 2)/729D Sea Battle 思维题
Galya is playing one-dimensional Sea Battle on a 1 × n grid. In this game a ships are placed on the ...
- Codeforces Round #367 (Div. 2) A. Beru-taxi (水题)
Beru-taxi 题目链接: http://codeforces.com/contest/706/problem/A Description Vasiliy lives at point (a, b ...
- Codeforces Round #575 (Div. 3) 昨天的div3 补题
Codeforces Round #575 (Div. 3) 这个div3打的太差了,心态都崩了. B. Odd Sum Segments B 题我就想了很久,这个题目我是找的奇数的个数,因为奇数想分 ...
- Codeforces Round #334 (Div. 2) A. Uncowed Forces 水题
A. Uncowed Forces Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/604/pro ...
- Codeforces Round #481 (Div. 3) D. Almost Arithmetic Progression
http://codeforces.com/contest/978/problem/D 题目大意: 给你一个长度为n的b(i)数组,你有如下操作: 对数组中的某个元素+1,+0,-1.并且这个元素只能 ...
- Codeforces Round #481 (Div. 3) G. Petya's Exams
http://codeforces.com/contest/978/problem/G 感冒是真的受不了...敲代码都没力气... 题目大意: 期末复习周,一共持续n天,有m场考试 每场考试有如下信息 ...
- Codeforces Round #481 (Div. 3) 全题解
A题,题目链接:http://codeforces.com/contest/978/problem/A 解题心得:题意就是让你将这个数列去重,重复的数只保留最右边的那个,最后按顺序打印数列.set+m ...
- Codeforces Round #481 (Div. 3) C. Letters
题目地址:http://codeforces.com/contest/978/problem/C 题解:有n个宿舍,每个宿舍人不一样多,有m封信,每封信送给对应的第m间房间,问这封信是给第几个宿舍,第 ...
- Codeforces Round #481 (Div. 3) B. File Name
题目地址:http://codeforces.com/contest/978/problem/B 题解:一串文件名里不能出现连续的xxx,询问进行几次操作后,文件名才不会出现xxx. 方法:只要遍历一 ...
随机推荐
- 一文搞懂C#中类成员的可访问性
公众号「DotNet学习交流」,分享学习DotNet的点滴. 文末有总结,想快速浏览的朋友可直接看文末. 1.成员访问修饰符 在C#中类成员访问修饰符一共有5个,分别是public.private.p ...
- C# 泛型编译特性对性能的影响
C#作为一种强类型语言,具有丰富的泛型支持,允许开发者编写可以应对不同数据类型的通用代码.然而,在泛型编译时,针对结构和类作为泛型参数时,会对性能产生不同的影响. 泛型编译行为 在C#中,泛型编译行为 ...
- 0x00.常用名词、文件下载、反弹shell
下载文章 方法一:下载谷歌插件fireshot,捕捉整个页面 方法二:使用js代码 f12进入控制台,粘贴如下代码 (function(){ $("#side").remove() ...
- 大模型那么火,教你一键Modelarts玩转开源LlaMA(羊驼)大模型
本文分享自华为云社区<大模型那么火,教你一键Modelarts玩转开源LlaMA(羊驼)大模型>,作者:码上开花_Lancer . 近日, LlaMA(羊驼)这个大模型再次冲上热搜! LL ...
- Java中的并发队列
1.队列 队列是一种数据结构.它有两个基本操作:在队列尾部加入一个元素,和从队列头部移除一个元素(注意不要弄混队列的头部和尾部)就是说,队列以一种先进先出的方式管理数据,如果你试图向一个 已经满了的阻 ...
- 51Nod - 1086 多重背包
有N种物品,每种物品的数量为C1,C2......Cn.从中任选若干件放在容量为W的背包里,每种物品的体积为W1,W2......Wn(Wi为整数),与之相对应的价值为P1,P2......Pn(Pi ...
- 字节国际化TnS算法实习的碎碎念
Motivation 在保研之后,我和南大的导师投了一篇个性化联邦学习的CVPR作为毕设.之后感觉就没什么事了,于是想着找个实习吧,第一个想法就是去字节实习,也只投了字节(别学我,还是多投一些哈哈,找 ...
- AntDesignBlazor示例——Modal表单
本示例是AntDesign Blazor的入门示例,在学习的同时分享出来,以供新手参考. 示例代码仓库:https://gitee.com/known/BlazorDemo 1. 学习目标 创建Mod ...
- .NET开发中合理使用对象映射库,简化和提高工作效率
前言 在日常开发中,我们常常需要将一个对象映射到另一个对象,这个过程中可能需要编写大量的重复性代码,如果每次都手动编写,不仅会影响开发效率,而且当项目越来越复杂,庞大的时候还容易出现错误.为了解决这个 ...
- pytest框架学习-标签@pytest.mark.
标签 自定义标签(区分大小写) 可以标记测试用例,对测试用例进行分组,有利于对测试用例进行筛选. 比如:给用例打标为API,代表接口自动化的用例,打标方法为@pytest.mark.API,打标后,需 ...