Algorithm
problem link- https://www.spoj.com/problems/PRO/
PRO - Promotion
A large Bytelandian supermarket chain has asked you to write a program for the simulating costs of a promotion being prepared.
The promotion has to follow the following rules:
- A customer who wants to participate in the promotion, writes on the receipt, paid by himself, his personal details and throws it into a special ballot box.
- At the end of every day of the promotion, two bills are taken out from the ballot box:
- first, the receipt amounting to the largest sum is chosen,
- then the receipt amounting to the smallest sum is chosen;
- To avoid multiple prizes for one purchase, both bills selected according to the above rules are not returned to the ballot box, but all remaining bills still participate in the promotion.
The turnover of the supermarket is very big, thus an assumption can be made, that at the end of every day, before taking out receipts amounting to the largest and the smallest sum, there are at least 2 receipts in the ballot box.
Your task is to compute (on the basis of information about prices on receipts thrown into the ballot box on each day of promotion) what the total cost of prizes during the whole promotion will be.
Write a program, which: reads from the standard input a list of prices on receipts thrown into the ballot box on each day of the promotion, computes the total cost of prizes paid in consecutive days of promotion, then writes the result to the standard output.
Input
The first line of the input contains one positive integer n (1 <= n <= 5000), which is the duration of promotion in days. Each of the next n lines consists of a sequence of non-negative integers separated by single spaces. Numbers in the (i+1)-th line of the file represent prices on receipts thrown into the ballot box on the i-th day of promotion. The first integer in the line is k, 0 <= k <= 10^5, the number of receipts on the day, and the next k numbers are positive integers standing for the sums on receipts; none of these numbers is larger than 10^6.
The total number of bills thrown into the ballot box during the whole promotion does not exceed 10^6.
Output
The output should contain exactly one integer, equal to the total cost of prizes paid during the whole promotion.
Example
Input: 5 3 1 2 3 2 1 1 4 10 5 5 1 0 1 2 Output: 19
Code Examples
#1 Code Example with C++ Programming
Code -
C++ Programming
#include <bits/stdc++.h>
#include <limits.h>
using namespace std;
typedef long long ll;
typedef pair<int, int> ii;
typedef vector<ii> vii;
typedef vector<int> vi;
#define MOD (ll)1000000007
#define pb push_back
#define EPS 1e-9
#define FOR(i, n) for(int i = 0;i < n; i++)
#define si(a) scanf("%d", &a)
#define pi(a) printf("%d\n", a)
template <typename T> T gcd(T a, T b){return (b==0)?a:gcd(b,a%b);}
template <typename T> T lcm(T a, T b){return a*(b/gcd(a,b));}
template <typename T> T mod_exp(T b, T p, T m){T x = 1;while(p){if(p&1)x=(x*b)%m;b=(b*b)%m;p=p>>1;}return x;}
template <typename T> T invFermat(T a, T p){return mod_exp(a, p-2, p);}
template <typename T> T exp(T b, T p){T x = 1;while(p){if(p&1)x=(x*b);b=(b*b);p=p>>1;}return x;}
int main(){
int n;
si(n);
ll ans = 0;
multiset<int> s;
multiset<int>::iterator it;
for(int i = 1;i <= n; i++){
int k;
si(k);
for(int j = 1;j <= k; j++){
int l;
si(l);
s.insert(l);
}
int val1 = *(s.begin());
set<int>::iterator it1 = s.begin();
it = s.end();
it--;
int val2 = *(it);
ans+=(val2-val1);
// cout<<val1<<' '<<val2<<endl;
s.erase(it);
s.erase(it1);
// cout<<s.size()<<endl;
}
printf("%lld\n", ans);
return 0;
}
Copy The Code &
Try With Live Editor
Input
3 1 2 3
2 1 1
4 10 5 5 1
0
1 2
Output
Demonstration
SPOJ Solution-Promotion-Solution in C, C++, Java, Python