A. Programming Contest

签到题.

输入输出读完应该就懂了:

从y1枚举到y2,若枚举的年份不在停办年份里则答案加一

void solve() {
int n,m;
cin >> n;
vector<int> a(N),year(N);
cin >> m;
for(int i = 0;i < m;i++){
int y;
cin >> y;
year[y] = 1;
}
int y;
cin >> y;
int ans = 0;
for(int i = n;i <= y;i ++)
if(!year[i])
ans++;
cout << ans << endl;
}

C. Trading

每次应该从价格最便宜的商店购买货物,并卖给价格最贵的商店。用双指针模拟这一贪心策略即可.

#include<bits/stdc++.h>
using namespace std; #define LL long long
void solve(){
LL n;
cin >> n;
vector<pair<LL,LL>> a;
for(LL i = 0;i < n;i ++){
LL x,y;
cin >> x >> y;
a.push_back({x,y});
}
LL sum = 0;
sort(a.begin(), a.end());
for(LL i = 0, j = n - 1; i < j; ){
LL x = min(a[i].second, a[j].second);
sum += (a[j].first - a[i].first) * x;
a[i].second -= x;
a[j].second -= x;
if(a[i].second == 0)
i++;
if(a[j].second == 0)
j--; }
cout << sum << endl;
} int main(){
ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
LL T;
cin>>T;
while(T--){
solve();
}
return 0;
}

D. New Houses

如果已知 \(k (2\le k \le n)\)个人有邻居,剩下的人没有邻居,怎样选择有邻居的人才能使总满意度最大化?

这是一个经典问题。先假设所有人都是没邻居的,得到总满意度 \(\sum\limits_{i = 1}^n b_i\) 。当第 \(i\) 个人从没邻居变成有邻居时,总满意度将增加 \((a_i - b_i)\)。因此选择 \((a_i - b_i)\) 最大的 \(k\) 个人变成有邻居的即可。排序后可以在 \(\mathcal{O}(n)\)的复杂度内一次性算出 $k = 2, \cdots, n $ 的最大总满意度。

如果 \(k\) 个人有邻居,剩下的人没有邻居,这样的布局至少需要 \(k + 2(n - k) = 2n - k\) 栋房子(即有邻居的人都住在最左边,然后每隔一栋房子住一个没邻居的人)。因此只有满足 \(2n - k \le m\) 才能考虑。

最后,别忘了考虑所有人都没有邻居的情况。这要求 \(m \ge 2n - 1\)。

#include <bits/stdc++.h>
#define endl '\n'
#define int long long using namespace std; const int N = 1e6+10, M = 998244353; typedef unsigned long long ll;
typedef pair<int,int> PII; int n,m,t,k;
map<int,int> mp;
void solve() {
cin >> n >> m;
vector<int> A(n + 1), B(n + 1),ve;
for(int i = 1;i <= n;i ++){
cin >> A[i] >> B[i];
ve.push_back(A[i] - B[i]);
} sort(ve.begin(), ve.end()); int ans = 0, now = 0;
for(int i = 1;i <= n;i ++)
now += B[i]; if(m >= 2 * n - 1)
ans = now; now += ve[n - 1];
for(int i =2;i <= n;i ++){
now += ve[n - i];
if(2 * n - i <= m)
ans = max(ans, now);
} cout << ans << endl;
}
signed main()
{
ios::sync_with_stdio(false);
cin.tie(0);cout.tie(0);
int Ke_scholar = 1;
cin >> Ke_scholar;
while(Ke_scholar--)
solve();
return 0;
}
/*
*/
 

I. Path Planning

假设答案为 \(x\),那么存在一条路径,使得从 \(0\) 到 \((x-1)\) 的每个整数都在路径上。这一条件满足二分性,因此我们可以二分答案 \(x\),并检查是否存在这样的路径。

由于每一步只能往右或者往下走,因此将路径上每个格子的坐标按行为第一关键字,列为第二关键字排序后,排在前面的坐标的列编号,一定小于等于排在后面的坐标的列编号。

因此,将从 0 到 \((x-1)\) 的每个整数所在的格子的坐标排序,并检查列编号是否满足以上条件,即可判断是否存在一条路径,使得这些整数都在路径上。实际实现时,不需要使用排序函数。只要依此枚举每个格子,若格子里的整数小于 \(x\) 则把格子加入 vector,这样得到的 vector 就已经按枚举的顺序排序了。

#include <bits/stdc++.h>
#define inf 0x3f3f3f3f
#define endl '\n'
#define int long long using namespace std; const int N = 1e6+10, M = 998244353; typedef unsigned long long ll;
typedef pair<int,int> PII; int n,m,t,k,a[N];
// 将从 0 到 x - 1 所在的格子坐标“排序”,检查前面的列坐标是否小于等于后面的列坐标
bool check(int x){
// 实际实现时,不需要使用排序函数,
// 直接按顺序枚举每个格子,若格子里的整数小于 x 则把格子加入 vector,
// 这样得到的 vector 就已经按枚举的顺序排序了
// 而且甚至连 vector 也不用真的维护,
// 因为我们只关心 vector 最后一个元素的列坐标,和当前列坐标的大小关系,
// 直接用变量 last 维护最后一个元素的列坐标即可
int last = 0;
for(int i = 0;i <n;i ++){
for(int j = 0;j < m;j ++){
if(a[i * m + j] < x){
if(last > j)
return false;
last = j;
}
}
} return true;
}
void solve() {
cin >> n >> m;
for(int i = 0;i < n;i ++)
for(int j = 0;j <m ;j++)
cin >> a[i * m + j]; int l = 0, r = n * m;
while(l < r){
int mid = (l + r + 1) >> 1;
if(check(mid)) l = mid ;
else r = mid - 1;
} cout << l << endl;
}
signed main()
{
ios::sync_with_stdio(false);
cin.tie(0);cout.tie(0);
int Ke_scholar = 1;
cin >> Ke_scholar;
while(Ke_scholar--)
solve();
return 0;
}
/*
*/
 

K. Peg Solitaire

因为数据范围很小,直接模拟暴力就能过

#include<bits/stdc++.h>

using namespace std;

const int N = 1e6+10;

#define int long long

int ans = 100;
int u[] = {0,2,0,-2};
int v[] = {2,0,-2,0};
int uu[] = {0,1,0,-1};
int vv[] = {1,0,-1,0};
int n,m,k;
void dfs(int x,int y, vector<vector<int>>& gg ){ for(int i = 0;i < 4;i ++){
int dx = u[i] + x;
int dy = v[i] + y;
int d1 = uu[i] + x;
int d2 = vv[i] + y;
if(dx > 0 && dy > 0 && dx <= n && dy <= m && gg[d1][d2] && !gg[dx][dy]){
gg[dx][dy] = 1;
gg[x][y] = gg[d1][d2] = 0;
for(int i = 1;i <= n;i ++){
for(int j = 1;j <= m;j ++){
if(gg[i][j]){
auto ggg = gg;
dfs(i,j,ggg);
}
}
}
gg[dx][dy] = 0;
gg[x][y] = gg[d1][d2] = 1;
}
}
int sum = 0;
for(int i = 1;i <= n;i ++)
for(int j = 1;j <= m;j ++)
if(gg[i][j])
sum++;
ans = min(ans, sum);
return ;
}
void solve(){
ans = 100;
cin >> n >> m >> k;
vector<vector<int> > g(n + 1, vector<int> (m + 1, 0));
for(int i = 0;i < k; i++){
int x,y;
cin >> x >> y;
g[x][y] = 1;
}
for(int i = 1;i <= n;i ++){
for(int j = 1;j <= m;j ++){
if(g[i][j]){
auto gg = g;
dfs(i,j,gg);
}
}
}
cout << ans << endl;
} int32_t main() {
ios::sync_with_stdio(false);
cin.tie(nullptr), cout.tie(nullptr);
int T;
cin>>T;
while(T--){
solve();
}
return 0;
}

其余题解参考2023 广东省大学生程序设计竞赛 - SUA Wiki

因为咱很懒,所以有的题解直接拿来用了

SMU Spring 2023 Contest Round 7的更多相关文章

  1. 2015 Astar Contest - Round 3 题解

    1001 数长方形 题目大意 平面内有N条平行于坐标轴的线段,且不会在端点处相交 问共形成多少个矩形 算法思路 枚举4条线段的全部组合.分别作为矩形四条边.推断是否合法 时间复杂度: O(N4) 代码 ...

  2. Contest Round #451 (Div. 2)F/Problemset 898F Restoring the Expression

    题意: 有一个a+b=c的等式,去掉两个符号,把三个数连在一起得到一个数 给出这个数,要求还原等式,length <= 1e6 三个数不能含有前导0,保证有解 解法: 铁头过题法,分类然后各种判 ...

  3. Codeforces Round #284 (Div. 2)A B C 模拟 数学

    A. Watching a movie time limit per test 1 second memory limit per test 256 megabytes input standard ...

  4. Sending messages to non-windowed applications -- AllocateHWnd, DeallocateHWnd

    http://delphi.about.com/od/windowsshellapi/l/aa093003a.htm Page 1: How Delphi dispatches messages in ...

  5. Codeforces 240 F. TorCoder

    F. TorCoder time limit per test 3 seconds memory limit per test 256 megabytes input input.txt output ...

  6. cf499B-Lecture 【map】

    http://codeforces.com/problemset/problem/499/B B. Lecture     You have a new professor of graph theo ...

  7. Why to Not Not Start a Startup

    我花了周六,周日两天的时间,把这篇长文给阅读完了.很受益,改变了我的很多认知,也给我开拓了视野. 转载: Want to start a startup? Get funded by Y Combin ...

  8. Codeforces 240F. TorCoder 线段树

    线段树统计和维护某一区间内的字母个数.. . . F. TorCoder time limit per test 3 seconds memory limit per test 256 megabyt ...

  9. 物联网学生科协第三届H-star现场编程比赛

    问题 A: 剪纸片 时间限制: 1 Sec 内存限制: 128 MB 题目描写叙述 这是一道简单的题目,假如你身边有一张纸.一把剪刀.在H-star的比赛现场,你会这么做: 1. 将这张纸剪成两片(平 ...

  10. [cf contest 893(edu round 33)] F - Subtree Minimum Query

    [cf contest 893(edu round 33)] F - Subtree Minimum Query time limit per test 6 seconds memory limit ...

随机推荐

  1. K-means聚类是一种非常流行的聚类算法

    K-means聚类是一种非常流行的聚类算法,它的目标是将n个样本划分到k个簇中,使得每个样本属于与其最近的均值(即簇中心)对应的簇,从而使得簇内的方差最小化.K-means聚类算法简单.易于实现,并且 ...

  2. FFmpeg开发笔记(三十一)使用RTMP Streamer开启APP直播推流

    ​RTMP Streamer是一个安卓手机端的开源RTMP直播推流框架,可用于RTMP直播和RTSP直播,其升级版还支持SRT直播(腾讯视频云就采用SRT协议).RTMP Streamer支持的视频编 ...

  3. Python 潮流周刊#57:Python 该采用日历版本吗?

    本周刊由 Python猫 出品,精心筛选国内外的 250+ 信息源,为你挑选最值得分享的文章.教程.开源项目.软件工具.播客和视频.热门话题等内容.愿景:帮助所有读者精进 Python 技术,并增长职 ...

  4. 使用kafka作为生产者生产数据到hdfs

    关键:查看kafka官网的userGuide 配置文件: agent.sources = r1agent.sinks = k1agent.channels = c1 ## sources config ...

  5. JDK9之后 Eureka依赖

    <!--Eureka添加依赖开始--> <dependency> <groupId>javax.xml.bind</groupId> <artif ...

  6. sshd管理限制登录配置(centos7.9)

    背景情况:为了公网的主机,被无限的密码爆破,需要对主机的ssh进行安装加固 1.首先要禁用root的远程登录和修改ssh的端口 vi /etc/ssh/sshd_config# 修改端口,不适用22端 ...

  7. Go微服务开发指南

    在这篇深入探讨Go语言在微服务架构中的应用的文章中,我们介绍了选择Go构建微服务的优势.详细分析了主要的Go微服务框架,并探讨了服务发现与注册和API网关的实现及应用. 关注TechLead,复旦博士 ...

  8. 如何在 XAMPP 中使用 不同的 PHP 版本?

    你有没有碰到这种情况,你工作的项目需要的是PHP8,而你自己的项目需要的是PHP7,而你又特别钟爱于XAMPP,奈何它却不能自由切换PHP版本,下面就讲下本人在用的方法将PHP7更新到PHP8,可以通 ...

  9. oeasy教您玩转vim - 37 - # 删除字符

    ​ 通过十进制的 ascii 值输入字符 在输入模式下 输入 ctrl + v 然后再输入 065 通过十六进制的 unicode 在输入模式下 输入 ctrl + v 然后再输入 u2642 就可以 ...

  10. 靶机: hard_socnet2

    靶机: hard_socnet2 准备 靶机:https://download.vulnhub.com/boredhackerblog/hard_socnet2.ova MD5 验证: 9d6bed1 ...