解题思路:其实就是使用n个加号和m个减号,可以随意使用括号,来使表达式的结果最大化。
分情况讨论
若 m == 0 ,只能全部求和
若 m != 0 ,则再分----没有负数:最小的数前面是减号,其余数前面是加号
----有正数也有负数:整数前面是加号,负数前面是减号
-----只有符数:取一个最大的数放在第一个位置,其余的数前面都是减号
注意事项:一个减号分配到k个数全加的括号中,去掉括号就变成了k个减号,一个减号分配到k个数全减的括号中,去括号就变成了一个减号和k-1个加号。
参考代码:
#include <bits/stdc++.h> using namespace std; int n, m; int main() { cin >> n >> m; int Max_a = -1e9 - 2, Min_a = 1e9 + 2; vector<int> a(n + m + 1); for (int i = 0; i < n + m + 1; ++i) { cin >> a[i]; Max_a = max(Max_a, a[i]); Min_a = min(Min_a, a[i]); } long long ans = 0; for (auto it = a.begin(); it != a.end(); ++it) ans += *it; if (m != 0) { if (Min_a >= 0) { ans -= Min_a * 2; } else { ans = 0; for (auto it = a.begin(); it != a.end(); ++it) ans += abs(*it); if (Max_a < 0) { ans += Max_a * 2; } } } cout << ans << endl; return 0; }
0.0分
9 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复