【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的模板竟 ...
随机推荐
- markdown---->Typora搭配uPic
记录一下在mac上面使用Typora和uPic来发表博客的过程,图床用的是阿里Oss.We all, whether we know it or not, are fighting to make t ...
- new 的原理是什么?通过 new 的方式创建对象和通过字面量 创建有什么区别?
涉及面试题: new 的原理是什么?通过 new 的方式创建对象和通过字面量 创建有什么区别? 在调用 new 的过程中会发生四件事情 新生成了一个对象: 链接到原型: 绑定 this : 返回新对象 ...
- 垃圾回收之CMS、G1、ZGC对比
ZGC(The Z Garbage Collector)是JDK 11中推出的一款低延迟垃圾回收器,它的设计目标包括: 停顿时间不超过10ms: 停顿时间不会随着堆的大小,或者活跃对象的大小而增加: ...
- 一个.Net简单、易用的配置文件操作库
在我们日常项目开发中,操作INI/CFG配置文件,往往会通过调用WinAPI来实现,WinAPI接口参数只支持字符串,而我们项目中,往往数据类型是多种多样的,在保存和获取配置值,我们就要进行类型的转换 ...
- [数据库/MYSQL]#解决缺陷#设置Unique索引时:"[Err] 1071 - Specified key was too long; max key length is 767 bytes"
1 问题复现 原表结构: CREATE TABLE `XX_TEMPERATURE` ( `FLOW_ID` int(11) NOT NULL COMMENT '独立的数据表或FTP唯一标识', -- ...
- 新旧版本功能对比 | v1.5.0 全新升级
Hi~社区的小伙伴们大家好呀! CloudQuery 最新 1.5.0 社区版本即将于 4月14日 发布,正式上线前,我们迫不及待与大家分享与 v1.4 相比,v1.5.0 在性能和功能上有哪些更新和 ...
- python从shp文件中读取经纬度数据
python从shp文件中读取经纬度数据 没有接触过GIS的人来说shp文件很陌生而且很难打开查看,好在python可以从中提取出自己想要的数据 pyshp库的安装 python的pyshp库可以实现 ...
- 关于Java中泛型的上界和下界理解
既然聊到了泛型的上下界问题,就先给出几个类的继承关系吧 class Fruit{}class Apple extends Fruit{}class Orange extends Fruit{}clas ...
- 基于Mongodb分布式锁简单实现,解决定时任务并发执行问题
前言 我们日常开发过程,会有一些定时任务的代码来统计一些系统运行数据,但是我们应用有需要部署多个实例,传统的通过配置文件来控制定时任务是否启动又太过繁琐,而且还经常出错,导致一些异常数据的产生 网上有 ...
- Kubuesphere部署Ruoyi(二):部署kubesphere
先决条件: 更换DNS 更换apt的镜像源 Ubuntu下永久性修改DNS vi /etc/systemd/resolved.conf DNS字段取消注释,并修改DNS为223.5.5.5 223.5 ...