Timus 1025. Democracy in Danger 题解
来源:互联网 发布:windows installer恢复 编辑:程序博客网 时间:2024/05/18 22:14
Background
In one of the countries of Caribbean basin all decisions were accepted by the simple majority of votes at the general meeting of citizens (fortunately, there were no lots of them). One of the local parties, aspiring to come to power as lawfully as possible, got its way in putting into effect some reform of the election system. The main argument was that the population of the island recently had increased and it was to longer easy to hold general meetings.
The essence of the reform is as follows. From the moment of its coming into effect all the citizens were divided into K (may be not equal) groups. Votes on every question were to be held then in each group, moreover, the group was said to vote “for” if more than half of the group had voted “for”, otherwise it was said to vote “against”. After the voting in each group a number of group that had voted “for” and “against” was calculated. The answer to the question was positive if the number of groups that had voted “for” was greater than the half of the general number of groups.
At first the inhabitants of the island accepted this system with pleasure. But when the first delights dispersed, some negative properties became obvious. It appeared that supporters of the party, that had introduced this system, could influence upon formation of groups of voters. Due to this they had an opportunity to put into effect some decisions without a majority of voters “for” it.
Let’s consider three groups of voters, containing 5, 5 and 7 persons, respectively. Then it is enough for the party to have only three supporters in each of the first two groups. So it would be able to put into effect a decision with the help of only six votes “for” instead of nine, that would be necessary in the case of general votes.
Problem
You are to write a program, which would determine according to the given partition of the electors the minimal number of supporters of the party, sufficient for putting into effect of any decision, with some distribution of those supporters among the groups.
Input
In the first line an only odd integer K — a quantity of groups — is written (1 ≤ K ≤ 101). In the second line there are written K odd integers, separated with a space. Those numbers define a number of voters in each group. The population of the island does not exceeds 9999 persons.
Output
You should write a minimal quantity of supporters of the party, that can put into effect any decision.
Sample
35 7 5
6
有两个思路:
1 先排序,然后从最小的值中取半数+1的值,就得到解了
2 使用priority_queue,就可以不排序,直接大数出列,小数入列,也可以很容易解决。
两个思路的时间效率都是O(n),但是运行起来应该是第二个思路比较快点。
这里使用priority_queue来解题。
#include <algorithm>#include <iostream>#include <queue>using namespace std;void DemocracyInDanger1025(){int k = 0, ans = 0, a = 0;cin>>k;priority_queue<int> pqu;int i = 0;for ( ; i <= (k>>1); i++){cin>>a;a = (a>>1) + 1;pqu.push(a);ans += a;}for ( ; i < k; i++){cin>>a;a = (a>>1) + 1;if (a < pqu.top()){ans -= pqu.top() - a;pqu.pop();pqu.push(a);}}cout<<ans;}int main(){DemocracyInDanger1025();return 0;}
1 0
- Timus 1025. Democracy in Danger 题解
- 1025. Democracy in Danger
- URAL 1025. Democracy in danger
- Ural-1025. Democracy in Danger(水题)
- URAL 1025. Democracy in Danger (贪心)
- poj2370 Democracy in danger!
- ural 1025 Democracy in Danger
- POJ 2370 Democracy in danger
- POJ 2370 Democracy in Danger
- 11 URAL1025 Democracy in Danger
- poj 2370 Democracy in danger
- Overcome ACM POJ 2370 - Democracy in danger
- URAL 1025 — Democracy in Danger
- Ural 1025 Democracy in Danger 解题报告
- URAL 1025 Democracy in Danger 贪心
- (贪心5.2.7)URAL 1025 Democracy in Danger
- A Pilot in Danger!
- POJ 1781 In Danger
- LINK : fatal error LNK1123: failure during conversion to COFF: file invalid or corrupt
- 沉默中等待(愿与君共勉)
- PHP解释器引擎执行流程
- 一个操作系统的实现_十分钟完成的操作系统
- poj 3762 The Bonus Salary! 需离散化
- Timus 1025. Democracy in Danger 题解
- PAT1007 BASIC:素数对猜想 (20)
- asdasdasd来不来啊
- Keepalived工具安装
- Access restriction: The type BASE64Encoder is not accessible due to restrict
- sgu495
- 类 HttpURLConnection
- 恩恩,迁移完成。。。
- ZOJ-1508