部分代码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. 高德地图和echarts结合实现地图下钻(一)

    疫情大屏优化-ECharts 地图下钻功能实现 https://www.sohu.com/a/373917631_100123073   全国:100000                北京:110 ...

  2. 数组栈(ArrayStack)

    栈   栈是一种线性结构,相比与数组,栈对应的操作时数组的子集,只能从一端添加元素,也只能从一端取出元素,是一种 后进先出(Last In First Ou,LIFO) 的数据结构. push pop ...

  3. #二分图,并查集#洛谷 6185 [NOI Online #1 提高组] 序列

    题目 分析 考虑2操作可以在保证总和不变的情况下任意修改, 如果将2操作所在的连通块用并查集缩点,那么再考虑1操作, 按照1操作建边,如果存在奇环,那么只要这个环的点权和为偶数一定能使 \(a,b\) ...

  4. #对顶堆#nssl 1477 赛

    分析 首先按小到大排序,考虑枚举两个都喜欢的个数\(i\) 那么只喜欢一个的个数各需要\(k-i\),剩下要补充到\(m-k*2+i\)个, 考虑用对顶堆维护大根堆大小仅有\(m-k*2+i\)即可 ...

  5. C#中base关键字的几种用法 (base可以对派生类(子类)实例中调用基类(父类)的构造函数方法或者基类上已经被重写的虚方法)

    base最大的使用就是"面向对象"开发的多态中.base可以对派生类(子类)实例中调用基类(父类)的构造函数方法或者基类上已经被重写的虚方法. 首先声明两个类 A B public ...

  6. RabbitMQ 08 路由模式

    路由模式 路由模式结构图: 定义配置类. import org.springframework.amqp.core.Binding; import org.springframework.amqp.c ...

  7. HarmonyOS Codelab 优秀样例——购物应用,体验一次开发多端部署魅力

    一. 样例介绍 本篇Codelab基于自适应布局和响应式布局,实现购物应用在手机.折叠屏.平板不同屏幕尺寸设备上按不同设计显示.通过三层工程结构组织代码,实现一次开发,多端部署 . 手机运行效果如图所 ...

  8. Linux0.12内核源码解读(2)-Bootsect.S

    大家好,我是呼噜噜,在上一篇文章聊聊x86计算机启动发生的事?我们了解了x86计算机启动过程,MBR.0x7c00是什么?其中当bios引导结束后,操作系统接过计算机的控制权后,发生了哪些事?本文将揭 ...

  9. sql 语句系列(计算一个季度的开始日期和结束日期)[八百章之第二十三章]

    前言 很多时候,我们进行数据库查询的时候,查询一个季度的财务报表的时候. 比如说查询2020年第一季度的单子,可能传入后台的就是20201,表示的就是20201第一季度,这时候我们要转换为日期. se ...

  10. redis 简单整理——java 客户端jedis[十六]

    前言 简单介绍一下java客户端jedis. 正文 Java有很多优秀的Redis客户端(详见:http://redis.io/clients#java),这 里介绍使用较为广泛的客户端Jedis,本 ...