部分代码define了long long,请记得开long long

A. Calandar

把年份、月份、单个的天数全都乘以对应的系数转化成单个的天数即可,注意最后的结果有可能是负数,要转化成正数。发现技巧是:(ans % 5 + 5) % 5。?

还有注意不能这样写,答案不正确。或许是因为取模运算没有这样的性质??

ans = plu(sub(plu(plu(mul(sub(y2, y), 365), mul(sub(m2, m), 30)), d2), d), x);
int y, m, d;
int y2, m2, d2; map<string, int> mp = {
{"Monday", 0},
{"Tuesday", 1},
{"Wednesday", 2},
{"Thursday", 3},
{"Friday", 4},
}; map<int, string> mpr = {
{0, "Monday"},
{1, "Tuesday"},
{2, "Wednesday"},
{3, "Thursday"},
{4, "Friday"},
}; void solve() {
cin >> y >> m >> d;
string s;
cin >> s;
int x = mp[s];
cin >> y2 >> m2 >> d2;
int ans = (y2 - y) * 365 + (m2 - m) * 30 + d2 - d + x;
if (ans >= 0) cout << mpr[ans % 5] << '\n';
else cout << mpr[(ans % 5 + 5) % 5] << '\n';
}

M. Sekiro

很简单的签到,但是把我害惨了,记得以前校某次比赛用过这题,当时就让我大脑宕机了一次。

注意到每次操作都会使\(n\)减半,因此最多只会操作\(log(n)\)次,但是有可能减半后和减半前值相同,造成死循环,因此这种情况要特判结束循环。

int n, k;

void solve() {
cin >> n >> k;
while (k --) {
if (n == (n + 1) / 2) break;
n = (n + 1) / 2;
}
cout << n << '\n';
}

F. Stones in the bucket

我们可以先将序列排个序,然后假设我们最后要把序列的元素全部变成\(x\),那么我们可以把所有\(>x\)的区块都一个个的撒给\(<x\)的区块,就像撒沙子那样。可以证明,只要大于\(x\)的量足够填满小于\(x\)的量,则一定是可以有方案实现这样填满,填满后剩下的部分用操作1扔掉即可。

故二分答案即可。

时间复杂度\(O(log(1e9)n)\)

int n;
int a[N]; bool check(int x) {
int sum0 = 0;
int sum1 = 0;
for (int i = 1; i <= n; i ++) {
if (a[i] < x) sum0 += x - a[i];
else sum1 += a[i] - x;
}
return sum1 >= sum0;
} void solve() {
cin >> n;
for (int i = 1; i <= n; i ++) {
cin >> a[i];
}
sort(a + 1, a + 1 + n);
int l = 0, r = 1e9 + 1;
while (l < r) {
int mid = l + r + 1ll >> 1ll;
if (check(mid)) l = mid;
else r = mid - 1;
}
int ans = 0;
for (int i = 1; i <= n; i ++) {
if (a[i] > l) ans += a[i] - l;
}
cout << ans << '\n';
}

C. Wandering robot

最让我头疼的一题,看完题解最想锤头的一题。

我刚开始一直在画图,想着算出前\(k-1\)次移动到的位置加上最后一次可以触及的最大曼哈顿距离即可。首先是分类讨论的头疼,接下来是发现可以统一为一种情况但是一直WA2的头疼。。。

正解是推导表达式看函数图像取最值。

设第\(i\)步之后坐标是\((x_i, y_i)\),则\((tn + i)\)步之后坐标是\((tx_n + x_i, ty_n + y_i)\),距离原点的曼哈顿距离是\(|tx_n + x_i| + |ty_n + y_i|\)。

函数\(f(t) = |tx_n + x_i|\)的图像是\(V形\),两个叠在一起可以通过画图得出。

这里引用官方题解的图。

可见该函数在左端点或者右端点取得最大值,因此我们只需要考虑\(t = 0\)和\(t = k - 1\)即可。

时间复杂度\(O(n)\)。

int n, k;
string s; void solve() {
cin >> n >> k;
cin >> s;
int X = 0, Y = 0;
for (int i = 0; i < n; i ++) {
if (s[i] == 'L') {
X --;
}
else if (s[i] == 'R') {
X ++;
}
else if (s[i] == 'U') {
Y ++;
}
else {
Y --;
}
}
int x = 0, y = 0;
int ans = 0;
for (int i = 0; i < n; i ++) {
if (s[i] == 'L') {
x --;
}
else if (s[i] == 'R') {
x ++;
}
else if (s[i] == 'U') {
y ++;
}
else {
y --;
}
ans = max({ans, abs(x) + abs(y), abs((k - 1) * X + x) + abs((k - 1) * Y + y)});
}
cout << ans << '\n';
}

第十届山东省大学生程序设计竞赛题解(A、F、M、C)的更多相关文章

  1. 《ACM国际大学生程序设计竞赛题解Ⅰ》——基础编程题

    这个专栏开始介绍一些<ACM国际大学生程序设计竞赛题解>上的竞赛题目,读者可以配合zju/poj/uva的在线测评系统提交代码(今天zoj貌似崩了). 其实看书名也能看出来这本书的思路,就 ...

  2. 华东师范大学第十届ECNU Coder程序设计竞赛

    华东师范大学第十届ECNU Coder程序设计竞赛 浮点数模运算 solution 转成整数然后取模. 时间复杂度:\(O(1)\) 数螃蟹 solution 找出公差出现次数最多的作为公差,然后找出 ...

  3. ZZUOJ-1195-OS Job Scheduling(郑州大学第七届ACM大学生程序设计竞赛E题)

    1195: OS Job Scheduling Time Limit: 2 Sec  Memory Limit: 128 MB Submit: 106  Solved: 35 [id=1195&quo ...

  4. FZU - 2295 Human life:网络流-最大权闭合子图-二进制优化-第九届福建省大学生程序设计竞赛

    目录 Catalog Solution: (有任何问题欢迎留言或私聊 && 欢迎交流讨论哦 http://acm.fzu.edu.cn/problem.php?pid=2295 htt ...

  5. 第 45 届国际大学生程序设计竞赛(ICPC)亚洲网上区域赛模拟赛. A.Easy Equation (前缀和/差分)

    题意:RT,给你四个数\(a,b,c,d\),求\(x+y+z=k\)的方案数. 题解:我们可以先枚举\(x\)的值,然后\(x+y\)能取到的范围一定是\([x,x+b]\),也就是说这个区间内每个 ...

  6. 第六届福建省大学生程序设计竞赛(FZU2213—FZU2221)

    from:piaocoder Common Tangents(两圆之间的公公切线) 题目链接: http://acm.fzu.edu.cn/problem.php?pid=2213 解题思路: 告诉你 ...

  7. 《ACM国际大学生程序设计竞赛题解I》——6.10

    Pku 1143: Description Christine and Matt are playing an exciting game they just invented: the Number ...

  8. 《ACM国际大学生程序设计竞赛题解I》——6.11

    pku 1107: Description Weird Wally's Wireless Widgets, Inc. manufactures an eclectic assortment of sm ...

  9. 《ACM国际大学生程序设计竞赛题解I》——6.8

    Poj1068: Description Let S = s1 s2...s2n be a well-formed string of parentheses. S can be encoded in ...

  10. 《ACM国际大学生程序设计竞赛题解Ⅰ》——模拟题

    这篇文章来介绍一些模拟题,即一类按照题目要求将现实的操作转换成程序语言. zoj1003: On every June 1st, the Children's Day, there will be a ...

随机推荐

  1. OpenHarmony系统使用gdb调试init

      前言 OpenAtom OpenHarmony(简称"OpenHarmony")适配新的开发板时,启动流程init大概率会出现问题,其为内核直接拉起的第一个用户态进程,问题定位 ...

  2. 如何在OpenHarmony上使用SeetaFace2人脸识别库?

    简介 相信大部分同学们都已了解或接触过OpenAtom OpenHarmony(以下简称"OpenHarmony")了,但你一定没在OpenHarmony上实现过人脸识别功能,跟着 ...

  3. C++ 异常和错误处理机制:如何使您的程序更加稳定和可靠

    在C++编程中,异常处理和错误处理机制是非常重要的.它们可以帮助程序员有效地处理运行时错误和异常情况.本文将介绍C++中的异常处理和错误处理机制. 什么是异常处理? 异常处理是指在程序执行过程中发生异 ...

  4. Unity 检测FPS工具

    检测FPS工具 public class FPS : MonoBehaviour { public float f_UpdateInterval = 0.5F; private float f_Las ...

  5. UE4中HTC Vive 手柄如何抓取物体

    想知道 HTC Vive 手柄如何抓取物体? HTC Vive 的手柄有许多功能,在游戏里你可以用手柄射箭,可以用手柄拾取木棍等等,但是这些是如何设置的呢?来看看我们的公开课教程吧. 本期教程为上半部 ...

  6. 自己diy一个smi(可以监控gpu,cpu,memory)

    diy-smi 1.0(DIY System management interface) 在我们训练自己深度学习模型时,我们想看GPU信息,也想看CPU和内存信息.我常用的是nvidia-smi和ht ...

  7. lattice的ipexpress异常,解决办法

    最近ip服务器可能会遇到问题,建议客户把更新检查关掉.我们有对应的IP下载链接. https://www.latticesemi.com/ispupdate/ipexpress/ https://ra ...

  8. 论文研究区域图的制作方法:ArcGIS

      本文介绍基于ArcMap软件,绘制论文中研究区域示意图.概况图等的方法.   最近需要绘制与地学有关论文.文献中的研究区域概况图.对于这一类图片,我个人比较喜欢基于ArcMap与PPT结合的方式来 ...

  9. keycloak~jwt的rs256签名的验证方式

    接口地址 keycloak开放接口地址:/auth/realms/fabao/.well-known/openid-configuration rsa算法相关术语 RSA算法是一种非对称加密算法,其安 ...

  10. ArcPy自动绘制大量地图并设置地图要素:Python

      本文介绍基于Python语言中ArcPy模块,实现ArcMap自动批量出图,并对地图要素进行自定义批量设置的方法. 1 任务需求   首先,我们来明确一下本文所需实现的需求.   现有通过Pyth ...