【LGR-142-Div.4】洛谷入门赛 #13 赛后总结
A.魔方
目测入门 -,就是需要开long long
//1
#include<bits/stdc++.h>
typedef long long valueType;
int main() {
valueType N;
std::cin >> N;
std::cout << 8 << ' ' << (12 * (N - 2)) << ' ' << (6 * (N - 2) * (N - 2)) << std::flush;
return 0;
}
B.教学楼
突然想起来刚学OI的时候三个数排序手打 6 个if,,,
//2
#include<bits/stdc++.h>
int main() {
int n, a, b, c;
std::cin >> n >> a >> b >> c;
if(std::min({a, b, c}) == a && n <= 3)
std::cout << "library" << std::flush;
else if(std::min({b, c}) == b && n <= 5)
std::cout << "comprehensive" << std::flush;
else if(n <= 9)
std::cout << "art" << std::flush;
return 0;
}
C.课桌
\]
//3
#include<bits/stdc++.h>
int main() {
long long n, x;
std::cin >> n >> x;
long long result = n * x;
for(int i = 1; i <= n; ++i) {
int t;
std::cin >> t;
result += t;
}
std::cout << result << std::flush;
}
D.教室
定义教室学生总数为 \(s\),则
\]
还需要注意如果整除的话,最后一排人数是 \(m\)。
//4
#include<bits/stdc++.h>
int main() {
long long n, m;
std::cin >> n >> m;
long long sum = 0;
for(int i = 1; i <= n; ++i) {
long long a, b, c;
std::cin >> a >> b >> c;
sum += a * b * c;
}
std::cout << (long long)(std::ceil((double)sum / m)) << ' ' << (long long)((sum % m == 0 ? m : sum % m)) << std::flush;
}
E.信
模拟。
//5
#include<bits/stdc++.h>
int main() {
long long n, x, y, a, b;
std::cin >> n >> x >> y >> a >> b;
long long t = 0, sum = 0, max = INT_MIN;
for(int i = 1; i <= n; ++i) {
int S, s, M;
std::cin >> S >> s >> M;
int const M0 = S * x + y * s;
if(M == M0) {
t = std::min(t - 1, (long long)-1);
if(t <= -b) {
sum = std::floor(sum / 2.0);
}
} else {
sum += (M - M0);
if(M > 2 * M0) {
sum += std::ceil((M - M0) / 2.0);
}
t = std::max(t + 1, (long long)1);
if(t >= a) {
sum <<= 1;
}
}
max = std::max(max, sum);
}
std::cout << max << ' ' << sum << std::flush;
}
F.纸条
不会。
G.棋
直接 \(\mathcal{O}(NM)\) 暴力判断有没有人胜利即可,需要注意数组越界和连续五个 ~。
//7
#include<bits/stdc++.h>
int main() {
int n, m;
std::cin >> n >> m;
std::vector<std::vector<char>> source;
source.resize(n + 200, std::vector<char>(m + 200));
for(int i = 1; i <= n; ++i)
for(int j = 1; j <= m; ++j)
std::cin >> source[i][j];
std::function<bool(int, int)> check = [&source, n, m] (int i, int j) {
char const now = source[i][j];
if(now != '*' && now != '$')
return false;
if(i - 4 >= 1)
if(source[i - 4][j] == now && source[i - 3][j] == now && source[i - 2][j] == now && source[i - 1][j] == now)
return true;
if(i + 4 <= n)
if(source[i + 4][j] == now && source[i + 3][j] == now && source[i + 2][j] == now && source[i + 1][j] == now)
return true;
if(j - 4 <= n)
if(source[i][j - 4] == now && source[i][j - 3] == now && source[i][j - 2] == now && source[i][j - 1] == now)
return true;
if(j + 4 <= n)
if(source[i][j + 4] == now && source[i][j + 3] == now && source[i][j + 2] == now && source[i][j + 1] == now)
return true;
if(i - 4 >= 1 && j - 4 >= 1)
if(source[i - 4][j - 4] == now && source[i - 3][j - 3] == now && source[i - 2][j - 2] == now && source[i - 1][j - 1] == now)
return true;
if(i - 4 >= 1 && j + 4 <= m)
if(source[i - 4][j + 4] == now && source[i - 3][j + 3] == now && source[i - 2][j + 2] == now && source[i - 1][j + 1] == now)
return true;
if(i + 4 <= n && j - 4 >= 1)
if(source[i + 4][j - 4] == now && source[i + 3][j - 3] == now && source[i + 2][j - 2] == now && source[i + 1][j - 1] == now)
return true;
if(i + 4 <= n && j + 4 <= m)
if(source[i + 4][j + 4] == now && source[i + 3][j + 3] == now && source[i + 2][j + 2] == now && source[i - 1][j + 1] == now)
return true;
return false;
};
int his = 0, her = 0;
for(int i = 1; i <= n; ++i) {
for(int j = 1; j <= m; ++j) {
if(source[i][j] == '*')
++her;
else if(source[i][j] == '$')
++his;
if(check(i, j)) {
std::cout << (source[i][j] == '*' ? "Pleasing!" : "zylwins!") << std::flush;
return 0;
}
}
}
if(his == her)
std::cout << "W" << std::flush;
else if(her == his + 1)
std::cout << "Z" << std::flush;
}
H.演唱会
到这里精神状态不佳,瞎打一通交上去发现有点分就不想动了。
I.std::cerr
第一题可以看出程序在 \(b = c - 1\) 的情况下会炸,(那个 \(-1\) 的锅)。
第二题通过通读题面和平日教训可以利用每次匹配成功在标准错误流输出的特点令其超时。
#include <iostream>
int main() {
int taskId;
std::cin >> taskId;
if (taskId == 1) {
std::cout << "1 2 3" << std::endl;
} else if (taskId == 2) {
int const t = 2e5;
std::cout << t << std::endl;
for(int i = 1; i <= t; ++i)
std::cout << "std::cerr\n";
}
}
【LGR-142-Div.4】洛谷入门赛 #13 赛后总结的更多相关文章
- 【LGR-(-8)】洛谷入门赛 #5 题解
比赛链接 9道题. 注:题目名称中链接为题目链接,题号中链接为比赛内链接 题目编号 洛谷题号 题目名称 题目难度 A P5713 [深基3.例5]洛谷团队系统 \(\color{red}{入门}\) ...
- war2 洛谷模拟赛day2 t3 状压
(new ) war2 题解:总体数据而言,我们很容易想到着就是DP啊,我们DP数组,用状态压缩,代表有那些点已经被占领过了,代表上一次我占的是那个.对于每一次状态转移,若当前我们要占领的Port ...
- 洛谷p3803 FFT入门
洛谷p3803 FFT入门 ps:花了我一天的时间弄懂fft的原理,感觉fft的折半很神奇! 大致谈一谈FFT的基本原理: 对于两个多项式的卷积,可以O(n^2)求出来(妥妥的暴力) 显然一个多项式可 ...
- 洛谷 P5594 【XR-4】模拟赛
洛谷 P5594 [XR-4]模拟赛 洛谷传送门 题目描述 X 校正在进行 CSP 前的校内集训. 一共有 nn 名 OIer 参与这次集训,教练为他们精心准备了 mm 套模拟赛题. 然而,每名 OI ...
- 草地排水 洛谷P2740 最大流 入门题目
草地排水 洛谷P2740 最大流入门题目 题意 在农夫约翰的农场上,每逢下雨,贝茜最喜欢的三叶草地就积聚了一潭水.这意味着草地被水淹没了,并且小草要继续生长还要花相当长一段时间.因此,农夫约翰修建了一 ...
- 洛谷 P5089: CodeForces #500 (Div. 1) B / 1012B : Chemical table
题目传送门:洛谷P5089. 题意简述: 一张 \(n \times m\) 的表格,有一些格子有标记,另外一些格子没有标记. 如果 \((r_1,c_1),(r_1,c_2),(r_2,c_1)\) ...
- 洛谷 P2015 二叉苹果树(codevs5565) 树形dp入门
dp这一方面的题我都不是很会,所以来练(xue)习(xi),大概把这题弄懂了. 树形dp就是在原本线性上dp改成了在 '树' 这个数据结构上dp. 一般来说,树形dp利用dfs在回溯时进行更新,使用儿 ...
- 洛谷P1667/[10.22 模拟赛] 数列 (思维+模拟)
洛谷P1667 数列 题目描述 给定一个长度是n的数列A,我们称一个数列是完美的,当且仅当对于其任意连续子序列的和都是正的.现在你有一个操作可以改变数列,选择一个区间[X,Y]满足\(A_X +A_{ ...
- 洛谷P1280 && caioj 1085 动态规划入门(非常规DP9:尼克的任务)
这道题我一直按照往常的思路想 f[i]为前i个任务的最大空暇时间 然后想不出来怎么做-- 后来看了题解 发现这里设的状态是时间,不是任务 自己思维还是太局限了,题做得太少. 很多网上题解都反着做,那么 ...
- 绝对是全网最好的Splay 入门详解——洛谷P3369&BZOJ3224: Tyvj 1728 普通平衡树 包教包会
平衡树是什么东西想必我就不用说太多了吧. 百度百科: 一个月之前的某天晚上,yuli巨佬为我们初步讲解了Splay,当时接触到了平衡树里的旋转等各种骚操作,感觉非常厉害.而第二天我调Splay的模板竟 ...
随机推荐
- 设计模式(三十)----综合应用-自定义Spring框架-自定义Spring IOC-定义bean、注册表相关类
现要对下面的配置文件进行解析,并自定义Spring框架的IOC对涉及到的对象进行管理. <?xml version="1.0" encoding="UTF-8&qu ...
- 垃圾回收之G1收集过程
G1 中提供了 Young GC.Mixed GC 两种垃圾回收模式,这两种垃圾回收模式,都是 Stop The World(STW) 的. G1 没有 fullGC 概念,需要 fullGC 时,调 ...
- Mybatis 获取自增主键 useGeneratedKeys与keyProperty 解答
Mybatis 获取自增主键 今天开发的时候遇到一个疑惑,业务场景是这样的, 但是百度好久没有找到合适的解答,于是自己向同事了解,感觉还不错,因此写上了这个文章 有一个表A和一个表B A就是一个主表, ...
- [数据库/MySQL]数据库备份与升级:MySQL Percona(RPM) 5.7.24-27 升级到 5.7.31-34
1 数据库升级方式:RPM包方式升级 [亲测有效] 环境 OS: CENTOS 7 DB: MYSQL 5.7.24-27 1.1 数据库备份 备份以防止升级失败 备份数据库的2个主要方法: 1)用M ...
- Linux搭建docker
### 1. 查看系统的内核版本 ```bash[root@wide ~]# uname -r3.10.0-1160.el7.x86_64``` ### 2. 将yum更新到最新版本 ```bash[ ...
- day91:luffy:基于vue+drf的路飞学城项目后端部署
目录 1.安装mysql镜像 2.把本地的数据导入到容器的mysql数据库中 3.安装redis容器 4.把后端项目部署前的处理 5.修改项目的配置文件:prod.py 6.从后端项目中收集静态文件 ...
- 在smt贴片加工中手工焊接和机器焊接的区别
在smt贴片加工领域,都需要将电子元件贴装在pcb板表面并进行焊接的,常用的焊接方式分为两种:手动焊接和全自动机器焊接,而常用的焊接机器有回流焊机和波峰焊机,那你知道他们的区别是什么吗?安徽英特丽带你 ...
- 随手记:Redis 部署到linux上面后,本地无法连接
修改redis的配置文件 redis.conf 1. bind 设置为 0.0.0.0 2. protected-mode 设置为no (也就是关闭保护模式) 3. daemonize 设置 ...
- 一文吃透Elasticsearch
本文已经收录到Github仓库,该仓库包含计算机基础.Java基础.多线程.JVM.数据库.Redis.Spring.Mybatis.SpringMVC.SpringBoot.分布式.微服务.设计模式 ...
- 即时通讯系统为什么选择GaussDB(for Redis)?
摘要:如果你需要一款稳定可靠的高性能企业级KV数据库,不妨试试GaussDB(for Redis). 每当网络上爆出热点新闻,混迹于各个社交媒体的小伙伴们全都开启了讨论模式.一条消息的产生是如何在群聊 ...