Run ID 作者 问题 语言 测评结果 分数 时间 内存 代码长度 提交时间
133882 周震东 K 次取反后最大化的数组和 C++ 解答错误 33 0 MS 256 KB 578 2024-03-02 10:17:47

Tests(1/3):


#include <bits/stdc++.h> using namespace std; int a[111111]; int main() { int n , k , sum = 0 , cnt = 0; cin >> n >> k; for(int i = 1 ; i <= n ; i++) { cin >> a[i]; if(a[i] < 0) { cnt++; } } sort(a + 1, a + n + 1); if(k >= cnt) { for(int i = 1 ; i <= k ; i++) { if(a[i] < 0)abs(a[i]); } } if(k - cnt >= 1) { for(int i = 1 ; i <= k - cnt ; i++) { if((k - cnt - i) % 2 == 0) { break; } else { a[i] -= (a[i] * 2); } } } for(int i = 1 ; i <= n ; i++) { sum += a[i]; } cout << sum; return 0; }


测评信息: