解题思路:其实就是使用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.0分

9 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论