部分代码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. jQuery获得或设置内容和属性、添加属性 append和after的区别

    来自w3school 在线教程 jQuery获得或设置内容和属性 text() - 设置或返回所选元素的文本内容 html() - 设置或返回所选元素的内容(包括 HTML 标记) val() - 设 ...

  2. 测试开发之系统篇-Docker容器安装

    前面文章我们讲到,容器是运行在宿主机上的一个进程,多个容器之间使用同一个宿主机上的操作系统内核.此处以Ubuntu20.04系统为例,介绍Docker容器引擎的安装过程. 安装 安装依赖. sudo ...

  3. vue3中router配置中的children怎么用

    在Vue 3中,当你使用Vue Router创建路由配置时, children属性允许你为某个路由定义嵌套路由.这意味着你可以在父路由下设置子路由,从而构建出具有层级结构的URL路径. 这里是一个基本 ...

  4. 使用OHOS SDK构建libwebp

    参照OHOS IDE和SDK的安装方法配置好开发环境. 从github下载源码. 执行如下命令: git clone --depth=1 https://github.com/webmproject/ ...

  5. 小师妹学JavaIO之:文件编码和字符集Unicode

    目录 简介 使用Properties读取文件 乱码初现 字符集和文件编码 解决Properties中的乱码 真.终极解决办法 总结 简介 小师妹一时兴起,使用了一项从来都没用过的新技能,没想却出现了一 ...

  6. Java中IO和NIO的本质和区别

    目录 简介 IO的本质 DMA和虚拟地址空间 IO的分类 IO和NIO的区别 总结 简介 终于要写到java中最最让人激动的部分了IO和NIO.IO的全称是input output,是java程序跟外 ...

  7. jenkins安装卸载和下载

    环境 :docker容器 卸载 jenkins 1.rpm卸载rpm -e jenkins 2.检查是否卸载成功rpm -ql jenkins 3.彻底删除残留文件:find / -iname jen ...

  8. 基于OT与CRDT协同算法的文档划词评论能力实现

    基于OT与CRDT协同算法的文档划词评论能力实现 当我们实现在线文档平台时,划词评论的功能是非常必要的,特别是在重文档管理流程的在线文档产品中,文档反馈是非常重要的一环,这样可以帮助文档维护者提高文档 ...

  9. stack smashing--canary报错利用

    stack smashing--canary报错利用 一般这种都是考察点比较狭窄,因为这个漏洞在libc2.23以上就被修复了,漏洞产生的原因是因为当覆盖掉canary的时候程序会报错,程序会执行 _ ...

  10. HarmonyOS 自定义页面请求与前端页面调试

      一.自定义页面请求响应 Web组件支持在应用拦截到页面请求后自定义响应请求能力.开发者通过onInterceptRequest()接口来实现自定义资源请求响应 .自定义请求能力可以用于开发者自定义 ...