-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathAmid-summer.cpp
More file actions
73 lines (66 loc) · 2.04 KB
/
Amid-summer.cpp
File metadata and controls
73 lines (66 loc) · 2.04 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
#include <iostream>
#include <algorithm>
#include <vector>
#include <map>
#include <utility>
#include <set>
#include <numeric>
using namespace std;
int Minimizar(vector<int> &v, int a, map<int,pair<set<int>,int>> &map, int &minSum){
int sum = 0;
for (auto x: v){
sum += abs(x-a);
}
//A partir do momento que a soma é maior, todas outras serão
if(sum > minSum)
return 0;
map[sum].first.insert(a);//Registra A ordernado nessa soma
map[sum].second++;//Quantas vezes deu essa soma
minSum = min(sum,minSum);
return 1;
}
void Minimizar(vector<int> v){
map<int,pair<set<int>,int>> map;
int A, countA = 0, totalA;
int sum = 0, minSum = INT32_MAX;
//Reparei que as minimas somas estão em torno da média
int mean = std::accumulate(v.begin(), v.end(), 0.0)/v.size();
//E se for interando A do minimo até o máximo, as somas vão diminuindo,
//em torna da média é minima, e depois aumenta
//Busca da média pra cima, e para quando acha uma soma maior que a minima
for (int a = mean; a <= *max_element(v.begin(),v.end()) ; ++a)
{
if(!Minimizar(v,a,map,minSum))
break;
}
//Busca da média pra baixo e para quando acha uma soma maior que a minima
for (int a = mean-1; a >= *min_element(v.begin(),v.end()); --a)
{
if(!Minimizar(v,a,map,minSum))
break;
}
//Menor A
A = *map.begin()->second.first.begin();
//Quantos da entrada tem a soma minima
for (auto s: map.begin()->second.first)
countA += count(v.begin(), v.end(),s);
//Quantos inteiros satisfazem A
totalA = map.begin()->second.second;
cout << A << " " << countA << " " << totalA << endl;
}
int main(){
int n,x;
vector<int> v;
while (!cin.eof())
{
if(cin >> n){
for (int i = 0; i < n; ++i)
{
cin >> x;
v.push_back(x);
}
Minimizar(v);
v.clear();
}
}
}