【16届蓝桥杯寒假刷题营】第2期DAY5

5.变变数组 - 蓝桥云课

给定一个长度为 n 的整数数组 A,A 中第 i 个元素为 Ai​(1≤i≤n),你只能在 A 中选择一个元素 a,将 A 中所有数值等于 a 的元素变为 a2,请问变化后 A 中所有元素和的最大为多少。

输入格式

输入共 2 行。

第一行包含一个整数 n,表示整数数组 A 中元素的个数。

第二行包含 n 个整数,表示整数数组 A 中各个元素的值。

输出格式

输出共一行,包含一个整数,表示变换后 A 中所有元素和的最大值。

样例输入

复制代码
5
-3 1 0 2 2

样例输出

复制代码
14

评测数据规模

对于所有评测数据,1≤n≤1e5,−1e4≤Ai​≤1e4。

思路如下:

相当于暴力,先计算未被改变的总和,之后再分别计算改变这个数的总和,求出最大。

代码如下:

复制代码
#include<iostream>
#include<algorithm>
#include<map>
using namespace std;
typedef long long ll;
const ll N = 1e5+10;
ll n; 
ll maxn = -1e9;
ll sum;
int main(void)
{
	map <int,int> mp;
	cin >> n;
	for(ll i = 1 ; i <= n ; i++)
	{
		ll x;
		cin >> x;
		mp[x]++;
		sum += x;//先计算未改变的总和 
	}
	for(auto it = mp.begin() ; it != mp.end() ; it++) 
	{
		ll key = it->first;
		ll num = it->second; 
		maxn = max(maxn,sum - num*key + num*key*key);
	}
	cout << maxn;
	return 0;
}
相关推荐
列星随旋17 小时前
拓扑排序(Kahn算法)
算法
郝学胜-神的一滴17 小时前
Linux 高并发基石:epoll 核心原理 + LT/ET 触发模式深度剖析
linux·运维·服务器·开发语言·c++·网络协议
Hello!!!!!!18 小时前
C++基础(六)——数组与字符串
c++·算法
山半仙xs18 小时前
基于卡尔曼滤波的人脸跟踪
人工智能·python·算法·计算机视觉
天若有情67318 小时前
反向封神!C++ 全局单例不避反用,实现无锁多线程函数独占访问
java·javascript·c++
智者知已应修善业18 小时前
【51单片机调用__TIME__无法实时时间】2023-7-10
c++·经验分享·笔记·算法·51单片机
做时间的朋友。18 小时前
算法-最大单入口空闲区域
算法
凤凰院凶涛QAQ18 小时前
《C++转JAVA快速入手系列》:基本通用语法篇
java·开发语言·c++
千寻girling18 小时前
机器学习 | 逻辑回归 | 尚硅谷学习
java·人工智能·python·学习·算法·机器学习·逻辑回归
Shadow(⊙o⊙)19 小时前
C++常见错误解析2.0
开发语言·数据结构·c++·后端·学习·算法