2019 JUST Programming Contest I. Array Negations

I. Array Negations

题目链接-I. Array Negations
在这里插入图片描述
在这里插入图片描述
题目大意
给你一个含 n n n个元素的数组,你必须进行k个求反操作,即每次操作都从数组中选择一个元素 a i ai ai,并将其替换为 − a i −ai ai,请你输出在进行 k k k的取反操作之后,数组 a a a所有元素的最大和

解题思路
$贪心$4

  • 先将所有元素排序,若负数数目大于 k k k,就把前 k k k个数取反,然后计算数组元素和输出即可
  • 若负数数目小于等于 k k k,就把所有负数取反,然后判断所有负数取反后,剩余次数是奇数还是偶数
  • 若为偶数,即可对任意一个数进行偶数次取反操作,这时数的大小不会发生改变,所以直接计算数组元素和输出即可
  • 若为奇数,可将操作后数组排序,然后将第一个元素取反即可,此时可保证 k k k次操作后数组元素和最大
  • 具体操作见代码

附上代码

#pragma GCC optimize("-Ofast","-funroll-all-loops")
#include<bits/stdc++.h>
#define int long long
#define lowbit(x) (x &(-x))
#define endl '\n'
using namespace std;
const int INF=0x3f3f3f3f;
const int dir[4][2]={-1,0,1,0,0,-1,0,1};
const double PI=acos(-1.0);
const double e=exp(1.0);
const double eps=1e-10;
const int M=1e9+7;
const int N=2e4+10;
typedef long long ll;
typedef pair<int,int> PII;
typedef unsigned long long ull;
int a[N];
signed main(){
	ios::sync_with_stdio(false);
	cin.tie(0);cout.tie(0);

	int t;
	cin>>t;
	while(t--){
		int n,k,ans=0;
		cin>>n>>k;
		for(int i=0;i<n;i++)
			cin>>a[i];
		sort(a,a+n);
		for(int i=0;i<n&&k;i++){
			if(a[i]<0){
				a[i]=-a[i];
				k--;
			}
			else break;
		}
		if(k%2){
			sort(a,a+n);
			a[0]=-a[0];
		}
		for(int i=0;i<n;i++)
			ans+=a[i];
		cout<<ans<<endl;
	}
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值