CF 1132 B. Discounts
Description
You came to a local shop and want to buy some chocolate bars. There are n bars in the shop, i-th of them costs ai coins (and you want to buy all of them).
You have m different coupons that allow you to buy chocolate bars. i-th coupon allows you to buy qi chocolate bars while you have to pay only for the qi−1 most expensive ones (so, the cheapest bar of those qi bars is for free).
You can use only one coupon; if you use coupon i, you have to choose qi bars and buy them using the coupon, and buy all the remaining n−qi bars without any discounts.
To decide which coupon to choose, you want to know what will be the minimum total amount of money you have to pay if you use one of the coupons optimally.
Input
The first line contains one integer n (2≤n≤3⋅1e5) — the number of chocolate bars in the shop.
The second line contains n integers a1, a2, ..., an (1≤ai≤1e9), where ai is the cost of i-th chocolate bar.
The third line contains one integer m (1≤m≤n−1) — the number of coupons you have.
The fourth line contains m integers q1, q2, ..., qm (2≤qi≤n), where qi is the number of chocolate bars you have to buy using i-th coupon so that the least expensive of them will be for free. All values of qi are pairwise distinct.
Output
Print m integers, i-th of them should be the minimum amount of money you have to pay if you buy qi bars with i-th coupon, and all the remaining bars one by one for their full price.
Example
input
7 7 1 3 1 4 10 8 2 3 4
output
27 30
Note
Consider the first example.
If we use the first coupon, we may choose chocolate bars having indices 1, 6 and 7, and we pay 18 coins for them and 9 coins for all other bars.
If we use the second coupon, we may choose chocolate bars having indices 1, 5, 6 and 7, and we pay 25 coins for them and 5 coins for all other bars.
Solution
思路:
累和,排序。对于每一次询问值q,输出总和减去第q大的值即可。
#include<iostream> #include<algorithm> #define ll long long using namespace std; int main(){ ll n,m,temp,sum=0; cin>>n; ll nums[n]; for(int i = 0;i<n;i++){ cin>>nums[i]; sum += nums[i]; } sort(nums,nums+n); cin>>m; while(m--){ cin>>temp; cout<<sum-nums[n-temp]<<endl; } return 0; }