SMU 2024 spring 天梯赛1
SMU 2024 spring 天梯赛1
7-1 种钻石 - SMU 2024 spring 天梯赛1 (pintia.cn)
#include <bits/stdc++.h>
#define debug(a) cout<<#a<<"="<<a<<'\n';
using namespace std;
using i64 = long long;
typedef pair<i64, i64> PII;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int n, v;
cin >> n >> v;
cout << n / v << '\n';
return 0;
}
7-2 1-1 输出金字塔图案 - SMU 2024 spring 天梯赛1 (pintia.cn)
*
***
*****
*******
//PHP
7-3 强迫症 - SMU 2024 spring 天梯赛1 (pintia.cn)
#include <bits/stdc++.h>
#define debug(a) cout<<#a<<"="<<a<<'\n';
using namespace std;
using i64 = long long;
typedef pair<i64, i64> PII;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
string n;
cin >> n;
if (n.size() < 6) {
if (n.substr(0, 2) < "22") {
n = "20" + n;
} else
n = "19" + n;
}
cout << n.substr(0, 4) << '-' << n.substr(4) << '\n';
return 0;
}
7-4 小孩子才做选择,大人全都要 - SMU 2024 spring 天梯赛1 (pintia.cn)
注意点,一个空碗一个不为空时,这时都处于亏的状态,但是全都要不一定就代表一点也吃不到
#include <bits/stdc++.h>
#define debug(a) cout<<#a<<"="<<a<<'\n';
using namespace std;
using i64 = long long;
typedef pair<i64, i64> PII;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int x,y;
cin >> x >> y;
if(x > 0 && y > 0){
cout << max(x,y) << ' ' << x + y << "\n^_^";
}else if(x < 0 && y < 0) {
cout << "0 0\n-_-";
}else{
cout << max(x,y) << ' ' << max(0,x+y) << "\nT_T";
}
return 0;
}
7-5 胎压监测 - SMU 2024 spring 天梯赛1 (pintia.cn)
模拟
#include <bits/stdc++.h>
#define debug(a) cout<<#a<<"="<<a<<'\n';
using namespace std;
using i64 = long long;
typedef pair<i64, i64> PII;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
vector<int> lun(6);
for (auto &i : lun) cin >> i;
int ma = lun[0];
for (int i = 0; i < 4; i ++)
ma = max(ma, lun[i]);
int ck = -1,num = 0;
for(int i = 0;i < 4;i ++){
int x = abs(lun[i] - ma);
if(x > lun[5] || lun[i] < lun[4]){
num ++, ck = i;
}
}
if(!num){
cout << "Normal";
}else if(num == 1){
cout << "Warning: please check #" << ck + 1 << '!';
}else{
cout << "Warning: please check all the tires!";
}
return 0;
}
7-6 吉老师的回归 - SMU 2024 spring 天梯赛1 (pintia.cn)
考察字符串
#include <bits/stdc++.h>
#define debug(a) cout<<#a<<"="<<a<<'\n';
using namespace std;
using i64 = long long;
typedef pair<i64, i64> PII;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int n, m;
cin >> n >> m;
string s;
getline(cin, s);
for (int i = 0; i < n; i ++) {
getline(cin, s);
if(s.find("qiandao") == -1 && s.find("easy") == -1){
m --;
if(m == -1){
cout << s << '\n';
exit(0);
}
}
}
cout << "Wo AK le";
return 0;
}
7-7 静静的推荐 - SMU 2024 spring 天梯赛1 (pintia.cn)
两个成绩都满足要求的,直接答案加一即可,就不参与推荐名额,把满足天梯赛成绩的筛选出来后,取每个分数段的前k个即可
#include <bits/stdc++.h>
#define debug(a) cout<<#a<<"="<<a<<'\n';
using namespace std;
using i64 = long long;
typedef pair<i64, i64> PII;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int n,k,s;
cin >> n >> k >> s;
int ans = 0;
vector<int> m(300);
for(int i = 0;i < n;i ++){
int a,b;
cin >> a >> b;
if(a < 175) continue;
if(b >= s) {
ans ++;
continue;
}
m[a] ++;
}
for(int i = 175;i <= 290;i ++)
ans += (m[i] > k ? k : m[i]);
cout << ans << '\n';
return 0;
}
7-8 机工士姆斯塔迪奥 - SMU 2024 spring 天梯赛1 (pintia.cn)
把选中的行和列都移到边界,最终答案仍然是个矩形,注意重复选择的行和列
#include <bits/stdc++.h>
#define debug(a) cout<<#a<<"="<<a<<'\n';
using namespace std;
using i64 = long long;
typedef pair<i64, i64> PII;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
i64 n,m,q;
cin >> n >> m >> q;
vector<array<int,2>> vis(100100);
for(int i = 0;i < q;i ++){
int op,x;
cin >> op >> x;
if(vis[x][op]) continue;
vis[x][op] ++;
if(op) m--;
else n --;
}
cout << n * m << '\n';
return 0;
}
7-9 彩虹瓶 - SMU 2024 spring 天梯赛1 (pintia.cn)
模拟
#include <bits/stdc++.h>
#define debug(a) cout<<#a<<"="<<a<<'\n';
using namespace std;
using i64 = long long;
typedef pair<i64, i64> PII;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int n,m,k;
cin >> n >> m >> k;
while(k--){
stack<int> Q,now;
for(int i = 0;i < n;i ++){
int x;
cin >> x;
if(Q.size() > m) continue;
if(now.empty() && x == 1){
now.push(x);
}else if(now.size() && x == now.top() + 1){
now.push(x);
}else Q.push(x);
if(now.size()){
while(Q.size() && Q.top() == now.top() + 1){
now.push(Q.top());
Q.pop();
}
}
}
if(now.size() != n)
cout << "NO\n";
else cout << "YES\n";
}
return 0;
}
7-10 简单计算器 - SMU 2024 spring 天梯赛1 (pintia.cn)
模拟
#include <bits/stdc++.h>
#define debug(a) cout<<#a<<"="<<a<<'\n';
using namespace std;
using i64 = long long;
typedef pair<i64, i64> PII;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int n;
cin >> n;
vector<int> num(n);
for (auto &i : num) cin >> i;
vector<char> op(n - 1);
for (auto &i : op) cin >> i;
while (num.size() > 1) {
int x = num.back();
num.pop_back();
int y = num.back();
num.pop_back();
char z = op.back();
op.pop_back();
switch (z) {
case '+': num.push_back(x + y);
break;
case '-': num.push_back(y - x);
break;
case '*': num.push_back(x * y);
break;
case'/': if (!x) {
cout << "ERROR: " << y << "/0\n";
exit(0);
} else {
num.push_back(y / x);
break;
}
}
}
cout << num[0] << '\n';
return 0;
}
7-11 龙龙送外卖 - SMU 2024 spring 天梯赛1 (pintia.cn)
假设每次送完后都要回到外卖站,则通过画图可以发现,其实每条路都走了两遍,现在加上不必返回外卖站,那我们只要把离外卖站即根节点最远的那条路线放到最后走,即只需走一遍,在之前的每条路的基础上减去最远的那条线即可
刚开始用了LCA,不过跟这题没关系,只需要计算每个点的深度以及记录其父节点,然后往上递归即可;
#include <bits/stdc++.h>
#define debug(a) cout<<#a<<"="<<a<<'\n';
using namespace std;
using i64 = long long;
typedef pair<i64, i64> PII;
struct LCA {
int n;
vector<i64> dep;
vector<vector<int>> e;
vector<array<int, 21>> fa;
LCA() {}
LCA(int n) {
dep.resize(n + 1);
e.resize(n + 1);
fa.resize(n + 1);
}
void add(int u, int v) {
e[u].push_back(v);
e[v].push_back(u);
}
//计算深度,处理各点祖先
void dfs(int u, int father) {
dep[u] = dep[father] + 1;
fa[u][0] = father;
for (int i = 1; i < 20; i ++)
fa[u][i] = fa[fa[u][i - 1]][i - 1];
for (auto v : e[u])
if (v != father)
dfs(v, u);
}
//最近公共祖先
//两点集并的最近公共祖先为两点几分别的最近公共祖先的最近公共祖先,
//即LCA(A∪B) = LCA(LCA(A), LCA(B));
int lca(int u, int v) {
if (dep[u] < dep[v]) swap(u, v);
for (int i = 19; i >= 0; i --)
if (dep[fa[u][i]] >= dep[v])
u = fa[u][i];
if (u == v) return v;
for (int i = 19; i >= 0; i --)
if (fa[u][i] != fa[v][i])
u = fa[u][i], v = fa[v][i];
return fa[u][0];
}
//d(u,v) = h(u) + h(v) - 2h(LCA(u,v));
//其中d是树上两点间的距离,h代表某点到树根的距离
int get_dis(int u, int v) {
return dep[u] + dep[v] - 2 * dep[lca(u, v)];
}
};
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int n, m, root;
cin >> n >> m;
LCA lca(n);
for (int i = 1; i <= n; i ++) {
int x;
cin >> x;
if (x == -1) root = i, x ++;
lca.add(x, i);
}
lca.dfs(root, 0);
i64 ans = 0;
vector<bool> vis(n + 1);
vis[root] = 1;
auto dfs = [&](auto self, int u)->void{
if (vis[u]) return ;
vis[u] = 1;
ans += 2;
self(self, lca.fa[u][0]);
};
i64 ma = 0;
while (m --) {
int x;
cin >> x;
ma = max(ma, lca.dep[x]);
dfs(dfs, x);
cout << ans - ma + 1 << '\n';
}
return 0;
}
7-12 智能护理中心统计 - SMU 2024 spring 天梯赛1(补题) (pintia.cn)
维护每个管理节点的人数,管理中心与管理中心的从属关系,老人与管理中心的从属关系;
每加入/移除一个老人,从当前老人的管理中心往上递归加一/减一;
管理中心之间从属关系,就往上递归给其上级添加此中心的人数;
查询时,先将老人从原来的管理中心移除,再添加到新的管理中心;
#include <bits/stdc++.h>
#define debug(a) cout<<#a<<"="<<a<<'\n';
using namespace std;
using i64 = long long;
typedef pair<i64, i64> PII;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int n, m;
cin >> n >> m;
map<int, int> num, fa, people;
map<string, int> id;
auto up = [&](auto up, int x)->void{
if (!x) return;
num[x] ++;
up(up, fa[x]);
};
auto down = [&](auto down, int x)->void{
if (!x) return ;
num[x] --;
down(down, fa[x]);
};
auto pass = [&](auto pass, int x, int val)->void{
if (!x) return ;
num[x] += val;
pass(pass, fa[x], val);
};
int cnt = 0;
for (int i = 0; i < m; i ++) {
string x, y;
cin >> x >> y;
if (!id[y]) id[y] = ++ cnt;
if (x[0] >= '0' && x[0] <= '9') {
people[stoi(x)] = id[y];
up(up, id[y]);
} else {
if (!id[x]) id[x] = ++ cnt;
fa[id[x]] = id[y];
pass(pass, id[y], num[id[x]]);
}
}
char op;
while (cin >> op) {
int x;
string y;
if (op == 'E') break;
else if (op == 'T') {
cin >> x >> y;
down(down, people[x]);
people[x] = id[y];
up(up, id[y]);
} else {
cin >> y;
cout << num[id[y]] << '\n';
}
}
return 0;
}
SMU 2024 spring 天梯赛1的更多相关文章
- 【CCCC天梯赛决赛】
cccc的天梯赛决赛,水题一样的水,中档题以上的还是没做出来.补了一下题,觉得其实也不是很难,主要是练的少. L2-1:红色预警 并查集 我做的时候想不到并查集,想到了也不一定做的出来,都是其实不难. ...
- 记第一届 CCCC-团体程序设计天梯赛决赛 参赛
其他都没什么,上午报道,下午比赛两个半小时,最后139分 但四我超遗憾的是,最后在做L3-1二叉搜索树,因为看到有辣么多人做出来,可是我没做出来啊 比赛结束后看了看其他两道当场吐血,L3-3直捣黄龙不 ...
- L1-049 天梯赛座位分配
L1-049 天梯赛座位分配 (20 分) 天梯赛每年有大量参赛队员,要保证同一所学校的所有队员都不能相邻,分配座位就成为一件比较麻烦的事情.为此我们制定如下策略:假设某赛场有 N 所学校参赛,第 i ...
- 团体程序设计天梯赛(CCCC) L3021 神坛 的一些错误做法(目前网上的方法没一个是对的) 和 一些想法
团体程序设计天梯赛代码.体现代码技巧,比赛技巧. https://github.com/congmingyige/cccc_code
- 团体程序设计天梯赛(CCCC) L3019 代码排版 方法与编译原理密切相关,只有一个测试点段错误
团体程序设计天梯赛代码.体现代码技巧,比赛技巧. https://github.com/congmingyige/cccc_code
- 团体程序设计天梯赛(CCCC) L3015 球队“食物链” 状态压缩
团体程序设计天梯赛代码.体现代码技巧,比赛技巧. https://github.com/congmingyige/cccc_code #include <cstdio> #include ...
- 第四届CCCC团体程序设计天梯赛 后记
一不小心又翻车了,第二次痛失200分 1.开局7分钟A了L2-3,一看榜已经有七个大兄弟排在前面了,翻车 * 1 2.把L1-3 A了18分,留了两分准备抢顽强拼搏奖,最后五秒钟把题过了,万万没想到还 ...
- 团体程序设计天梯赛(CCCC) L3014 周游世界 BFS证明
团体程序设计天梯赛代码.体现代码技巧,比赛技巧. https://github.com/congmingyige/cccc_code
- 团体程序设计天梯赛(CCCC) L3013 非常弹的球 不同思路
团体程序设计天梯赛代码.体现代码技巧,比赛技巧. https://github.com/congmingyige/cccc_code
- 团体程序设计天梯赛(CCCC) L3012 水果忍者 上凸或下凹的证明
团体程序设计天梯赛代码.体现代码技巧,比赛技巧. https://github.com/congmingyige/cccc_code #include <cstdio> #include ...
随机推荐
- TGI 基准测试
本文主要探讨 TGI 的小兄弟 - TGI 基准测试工具.它能帮助我们超越简单的吞吐量指标,对 TGI 进行更全面的性能剖析,以更好地了解如何根据实际需求对服务进行调优并按需作出最佳的权衡及决策.如果 ...
- ubuntu 18.04 设置开机自启
ubuntu 18.04 设置开机自启 背景 为了添加一些自定义的服务,例如autossh. 原文(有删改):https://zhuanlan.zhihu.com/p/98804785 介绍 ubun ...
- 【论文阅读】IROS2021: PILOT: Efficient Planning by Imitation Learning and Optimisation for Safe Autonomous Driving
参考与前言 完整题目:PILOT: Efficient Planning by Imitation Learning and Optimisation for Safe Autonomous Driv ...
- hadoop集群配置文件与功能对应解析
以三个节点的集群为例: 总括: nodemanager ,datanode --> slavesresourcemanager ----------> yarn namenode ...
- Spring Reactor基本介绍和案例
1. Reactor 对比 1.1 Reactor 线程模型 Reactor 线程模型就是通过 单个线程 使用 Java NIO 包中的 Selector 的 select()方法,进行监听.当获取到 ...
- 使用docker搭建ELK分式日志同步方案
ELK作为业界最常用日志同步方案,我们今天尝试一下使用docker快速搭建一套ELK方案.ELK使用国内加速源拉取的镜像比较旧,有条件的朋友可以拉取官网的源.elasticsearch作为日志储存库( ...
- SpringBoot AOP完美记录用户操作日志,附源码
记录内容 接口名称 浏览器名称 操作系统 请求ip 接口入参.出参 接口耗时 .... 表结构 SET NAMES utf8mb4; SET FOREIGN_KEY_CHECKS = 0; -- -- ...
- yb课堂 搭建node环境和npm安装 《二十六》
搭建node环境和npm安装 什么是NodeJS? Node.js就是运行在服务端得JavaScript 什么是npm? nodejs的包管理工具,可以下载使用公共仓库的包,类似maven包安装分为本 ...
- Docker下安装Nginx代理服务器【工作实操版】
一.Nginx下载 使用命令拉取nginx镜像到本地,此处我们获取排名第一的是官方最新镜像,其它版本可以去DockerHub查询 docker pull nginx 二.先启动一个nginx容器用于c ...
- [oeasy]python0081_ANSI序列由来_终端机_VT100_DEC_VT选项_终端控制序列
更多颜色 回忆上次内容 上次 首先了解了RGB颜色设置 可以把一些抽象的色彩名字 落实到具体的 RGB颜色 计算机所做的一切 其实就是量化.编码 把生活的一切都进行数字化 标准 是ANSI制定的 这个 ...