Educational Codeforces Round 108 (Rated for Div. 2) (A思维,Bmath,C前缀和,D枚举)
1519A. Red and Blue Beans
问题简述
给定 \(r\) 个红豆,\(b\) 个蓝豆,差值 \(d\) ,要求我们进行为红蓝豆分组,使得红豆和蓝豆绝对值差值不大于 \(d\) ,即:一个红豆最多与 \(d + 1\) 个蓝豆组合,反之亦然
问题分析
设数量小的豆子为 \(x\) ,数量多的豆子为 \(y\) 所以满足 $y \le x + x · d $ 输出 YES
代码解决
using ll = long long;
void solve() {
ll r, b, d;
cin >> r >> b >> d;
if (r < b) swap(r, b);
cout << (b + b * d >= r ? "YES\n" : "NO\n");
}
1519B. The Cake Is a Lie
问题简述
求从\((1,1)\) 移动至 \((n,m)\) 的 Cost是否等于 \(k\),每一步的代价:\((x,y) \to (x + 1,y)\) 代价为 \(y\) ,$(x,y) \to (x,y + 1) $ 的代价为 \(x\)
问题分析
可以通过DP或者数学的方法解决
这里贴一下暴力解法 DFS
int n, m, k;
ll cnt = 0;
void dfs(int x, int y, int val) {
if (x == n && y == m) {
cnt = val;
return;
}
if (x > n || y > m) return;
if (x < n)
dfs(x + 1, y, val + y);
else
dfs(x, y + 1, val + x);
}
void solve() {
cnt = 0;
cin >> n >> m >> k;
dfs(1, 1, 0);
cout << (cnt == k ? "YES\n" : "NO\n");
}
math:\(k = (m - 1) + m * (n - 1)\) 输出 YES
using ll = long long;
void solve() {
ll n, m, k;
cin >> n >> m >> k;
cout << (k == (m - 1) + m * (n - 1) ? "YES\n" : "NO\n");
}
1519C. Berland Regional
问题简述
某地方举办XCPC区域赛, \(n\) 个学生,分别来自 \(u_i\) 且每人的编程能力 \(s_i\) ,如果限定每个队伍必须 \(k\) 人,那么学校会安排 \(s_i\) 更大的人组队,并且每个学院可以派出多个队伍且保证每个队友刚好 \(k\) 人,当 \(k = 1,2,...n\) 时,求出所有学校参赛人的 \(\sum s_i\) ,当人数不够 \(k\) 时战力和为 \(0\) .
问题分析
把每个学生存到对应的学校,并按照从大到小降序存进数组 u[] 且对每个学校的该大小位size的数组进行前缀和s[],每个学校对 \(ans_k\) 的贡献是前 size-k%size(size/k*k) 个的前缀和
using ll = long long;
const int N = 2e5 + 7;
set<ll> st;
vector<ll> u[N];
bool cmp(pair<ll, ll> a, pair<ll, ll> b) { return a.first > b.first; }
void solve() {
int n;
cin >> n;
vector<pair<ll, ll>> p(n);
vector<ll> cnt(n + 2, 0);
st.clear();
for (int i = 0; i <= n; ++i) u[i].clear();
for (int i = 0; i < n; ++i) cin >> p[i].second, st.insert(p[i].second);
for (int i = 0; i < n; ++i) cin >> p[i].first;
sort(p.begin(), p.end(), cmp);
for (int i = 0; i < n; ++i) u[p[i].second].push_back(p[i].first);
for (auto i : st) {
int siz = u[i].size();
for (int j = 1; j < siz; j++) u[i][j] += u[i][j - 1];
for (int j = 1; j <= siz; j++) cnt[j] += u[i][siz - 1 - siz % j]; //关键是这里处理ans[]
}
for (int i = 1; i <= n; i++) cout << cnt[i] << " ";
cout << endl;
}
1519D. Maximum Sum of Products
问题简述
至多可以反转一次 a[] ,问最大的 \(\sum a_i*b_i\)
问题分析
T=2s,n=5000,直接枚举所有情况,所以考虑 \(a_i*b_i\) 的前缀和,枚举中点,且考虑翻转的长度奇偶,把翻转的 [l,r] 和 [l-1,r+1] 的式子展开发展不同点只有\(a[l-1]*b[r+1]+a[r+1]*b[l-1]\) ,左右两端用前缀和求和即可
using ll = long long;
ll a[5005], b[5005], s[5005], ans = 0;
int n;
void run1(int x) { //翻转长度位奇数
ll res = 0;
for (int l = x, r = x; l >= 1 && r <= n; l--, r++) {
if (l == r) res += a[l] * b[l];
else
res += a[l] * b[r] + a[r] * b[l];
ans = max(ans, res + s[l - 1] + s[n] - s[r]);
}
}
void run2(int x) { //翻转长度位偶数
ll res = 0;
for (int l = x, r = x + 1; l >= 1 && r <= n; l--, r++) {
if (l == r) res += a[l] * b[l];
else
res += a[l] * b[r] + a[r] * b[l];
ans = max(ans, res + s[l - 1] + s[n] - s[r]);
}
}
void solve() {
cin >> n;
for (int i = 1; i <= n; i++) cin >> a[i];
for (int j = 1; j <= n; j++) cin >> b[j];
for (int i = 1; i <= n; i++) s[i] = s[i - 1] + a[i] * b[i];
for (int i = 1; i <= n; i++) run1(i); //翻转长度位奇数
for (int i = 1; i <= n; i++) run2(i); //翻转长度位偶数
ans = max(ans, s[n]); //特判一下原来不翻转
cout << ans;
}
Educational Codeforces Round 108 (Rated for Div. 2) (A思维,Bmath,C前缀和,D枚举)的更多相关文章
- Educational Codeforces Round 88 (Rated for Div. 2) D. Yet Another Yet Another Task(枚举/最大连续子序列)
题目链接:https://codeforces.com/contest/1359/problem/D 题意 有一个大小为 $n$ 的数组,可以选取一段连续区间去掉其中的最大值求和,问求和的最大值为多少 ...
- Educational Codeforces Round 61 (Rated for Div. 2)-C. Painting the Fence 前缀和优化
题意就是给出多个区间,要求去掉两个区间,使得剩下的区间覆盖范围最大. 当然比赛的时候还是没能做出来,不得不佩服大佬的各种姿势. 当时我想的是用线段树维护区间和,然后用单点判0,维护区间间断个数.然后打 ...
- C. Brutality Educational Codeforces Round 59 (Rated for Div. 2) 贪心+思维
C. Brutality time limit per test 1 second memory limit per test 256 megabytes input standard input o ...
- Educational Codeforces Round 78 (Rated for Div. 2) C - Berry Jam(前缀和)
- 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 ...
- 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 ...
- Educational Codeforces Round 43 (Rated for Div. 2)
Educational Codeforces Round 43 (Rated for Div. 2) https://codeforces.com/contest/976 A #include< ...
- Educational Codeforces Round 35 (Rated for Div. 2)
Educational Codeforces Round 35 (Rated for Div. 2) https://codeforces.com/contest/911 A 模拟 #include& ...
- Codeforces Educational Codeforces Round 44 (Rated for Div. 2) F. Isomorphic Strings
Codeforces Educational Codeforces Round 44 (Rated for Div. 2) F. Isomorphic Strings 题目连接: http://cod ...
- Codeforces Educational Codeforces Round 44 (Rated for Div. 2) E. Pencils and Boxes
Codeforces Educational Codeforces Round 44 (Rated for Div. 2) E. Pencils and Boxes 题目连接: http://code ...
随机推荐
- 在路上---学习篇(一)Python 数据结构和算法 (5)二分查找、二叉树遍历
独白: 利用算法进行查找指定元素,最近学习二分查找和二叉树遍历.二分查找前提是在有序中进行查找,二叉树引入了树的概念.树的概念其中有许多小知识点,也是一种新的数据结构.还是之前的感悟,需了解其本质才会 ...
- 【scipy 基础】--统计分布
scipy.stats子模块包含大量的概率分布.汇总和频率统计.相关函数和统计测试.掩蔽统计.核密度估计.准蒙特卡罗功能等等. 这个子模块可以帮助我们描述和分析数据,进行假设检验和拟合统计模型等. 1 ...
- 大语言模型底层架构丨带你认识Transformer
本文分享自华为云社区<大语言模型底层架构你了解多少?大语言模型底层架构之一Transfomer的介绍和python代码实现>,作者: 码上开花_Lancer . 语言模型目标是建模自然语言 ...
- [python][图像切割]给定手写数字图片完成数字切割
import torch import torch.nn as nn from torchvision import transforms from PIL import Image, ImageOp ...
- 2023 年最后一波工具安利「GitHub 热点速览」
2023 年还有两周就要接近尾声了,2023 年的热点速览还有一波工具好安利:比如上周推荐之后上了热榜的远程调试工具 page-spy-web,让调试像呼吸一般自然方便:还有轻量级的搜索引擎 oram ...
- ElasticSearch之cat aliases API
执行aliases命令,如下: curl -X GET "https://localhost:9200/_cat/aliases?pretty&v=true" --cace ...
- 斯坦福 UE4 C++ ActionRoguelike游戏实例教程 05.认识GameMode&自动生成AI角色
斯坦福课程 UE4 C++ ActionRoguelike游戏实例教程 0.绪论 概述 本篇文章将会讲述UE中Gamemode的基本概念,并在C++中开发GameMode,为游戏设置一个简单的玩法:使 ...
- git blame 用法小记
1.概述 git管理的代码仓库,在协作开发中不可避免地会出现代码冲突,或者有新手错误地提交代码.出现问题不可怕,可怕的是找不到问题出在哪里.有时候找到出问题的代码,却不知道是谁提交的.git提供了一个 ...
- 为什么maven配置完Tomcat且运行之后页面内容没有显示出来?
1.如何在maven项目中配置一个webapp项目? 首先新建一个maven项目 项目目录 <?xml version="1.0" encoding="UTF-8& ...
- .Net 系列:Attribute特性的高级使用及自定义验证实现
一.特性是什么?特性有什么用? 特性(Attribute)是用于在运行时传递程序中各种元素(比如类.方法.结构.枚举.组件等)的行为信息的声明性标签. 您可以通过使用特性向程序添加声明性信息.一个声明 ...