题意:

Berland地区的腐败现象非常常见。

马上有一场选举,你事先知道了选民和政党的数量,分别为 n 和 m ,对于每一位选民,你知道他将要选举哪一个政党,

不过,每一位选民都会在接受一定数额的金钱之后改变他的主意。如果你给第 i 位选民 ci​ 数额的比特币,他就会选举任何你希望他选举的政党。

你的目的是让Berland的联合党赢得这场选举,联合党必须拥有比其它政党都多的选票,在此基础之上,你希望花费的比特币尽可能少。

联合党为1号党

n,m<=3e3,a[i]<=1e9

思路:同ZOJ3715

这个问题似乎没有全局的最优策略

枚举获得胜利需要的票数k,花费为两部分之和:

1.选票比1号多的党,选择其中花费最少的一些直到这些党的票数小于1号党

2.如果第一步之后票数不够,在剩下的票中选择花费最少的将1号党的票数补到k

  1. #include<cstdio>
  2. #include<cstring>
  3. #include<string>
  4. #include<cmath>
  5. #include<iostream>
  6. #include<algorithm>
  7. #include<map>
  8. #include<set>
  9. #include<queue>
  10. #include<vector>
  11. using namespace std;
  12. typedef long long ll;
  13. typedef unsigned int uint;
  14. typedef unsigned long long ull;
  15. typedef pair<int,int> PII;
  16. typedef vector<int> VI;
  17. #define fi first
  18. #define se second
  19. #define MP make_pair
  20. #define N 11000
  21. #define MOD 1000000007
  22. #define eps 1e-8
  23. #define pi acos(-1)
  24.  
  25. struct arr
  26. {
  27. ll x,y;
  28. }a[N];
  29.  
  30. ll c[N],d[N],flag[N];
  31.  
  32. int read()
  33. {
  34. int v=,f=;
  35. char c=getchar();
  36. while(c<||<c) {if(c=='-') f=-; c=getchar();}
  37. while(<=c&&c<=) v=(v<<)+v+v+c-,c=getchar();
  38. return v*f;
  39. }
  40.  
  41. bool cmp(arr a,arr b)
  42. {
  43. return a.y<b.y;
  44. }
  45.  
  46. int main()
  47. {
  48. // freopen("1.in","r",stdin);
  49. //freopen("1.out","w",stdout);
  50. int n,m;
  51. scanf("%d%d",&n,&m);
  52. for(int i=;i<=n;i++)
  53. {
  54. scanf("%lld%lld",&a[i].x,&a[i].y);
  55. c[a[i].x]++;
  56. }
  57. ll ans=;
  58. sort(a+,a+n+,cmp);
  59. //for(int i=1;i<=n;i++) printf("%d %d\n",a[i].x,a[i].y);
  60. for(int i=;i<=n;i++)
  61. {
  62. ll tmp=;
  63. ll now=;
  64. for(int j=;j<=m;j++) d[j]=c[j];
  65. for(int j=;j<=n;j++) flag[j]=;
  66. for(int j=;j<=n;j++)
  67. if(a[j].x==) now++;
  68. for(int j=;j<=n;j++)
  69. if(d[a[j].x]>=i&&a[j].x!=)
  70. {
  71. tmp+=a[j].y;
  72. d[a[j].x]--;
  73. now++;
  74. flag[j]=;
  75. }
  76. //printf("%d %lld\n",now,tmp);
  77. if(now<i)
  78. {
  79. for(int j=;j<=n;j++)
  80. {
  81. if((!flag[j])&&(a[j].x!=)) {tmp+=a[j].y; now++;}
  82. if(now>=i) break;
  83. }
  84. }
  85. if(tmp<ans&&now>=i) ans=tmp;
  86. // printf("%d %lld\n",i,tmp);
  87. }
  88. printf("%lld\n",ans);
  89. return ;
  90. }

【CF1020C】Elections(贪心)的更多相关文章

  1. CodeForces - 1020C C - Elections(贪心+枚举)

    题目: 党派竞争投票 有n个人,m个党派,这n个人每个人有一个想要投的党派的编号Pi,如果想要这个人改变他的想法,那么就需要花费Ci元钱. 现在你是编号为1的党派,如果你想要赢(你的票数严格大于其他党 ...

  2. Codeforces C. Elections(贪心枚举三分)

    题目描述: C. Elections time limit per test 2 seconds memory limit per test 256 megabytes input standard ...

  3. Codeforces Round #503 (by SIS, Div. 2) C. Elections (暴力+贪心)

    [题目描述] Elections are coming. You know the number of voters and the number of parties — n and m respe ...

  4. Elections CodeForces - 1020C (贪心)

    大意: 有n个选民, m个党派, 第i个选民初始投$p_i$一票, 可以花费$c_i$改变投票, 求最少花费使得第一个党派的票数严格最大 假设最终第一个党派得票数$x$, 枚举$x$, 则对于所有票数 ...

  5. Codeforces #503 C. Elections(贪心,逆向

    我的参考的博客地址 题目 逆向考虑. 暴力遍历 k(k是1到n/2+1 范围内的),挑出对于每一个k,记对于党派 i,num[ i ]为其票数.num[ i ]小于k-1的就不用改变投票了(这部分是比 ...

  6. codeforces 1020 C Elections(枚举+贪心)

    题意: 有 n个人,m个党派,第i个人开始想把票投给党派pi,而如果想让他改变他的想法需要花费ci元.你现在是党派1,问你最少花多少钱使得你的党派得票数大于其它任意党派. n,m<3000 思路 ...

  7. Debate CodeForces - 1070F (贪心)

    Elections in Berland are coming. There are only two candidates — Alice and Bob. The main Berland TV ...

  8. Codeforces Round #503 (by SIS, Div. 2) C. Elections(枚举,暴力)

    原文地址 C. Elections time limit per test 2 seconds memory limit per test 256 megabytes input standard i ...

  9. BZOJ 1692: [Usaco2007 Dec]队列变换 [后缀数组 贪心]

    1692: [Usaco2007 Dec]队列变换 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 1383  Solved: 582[Submit][St ...

随机推荐

  1. 理解AttributeUsage类

    类定义: // 摘要: // 指定另一特性类的用法. 此类不能被继承. [Serializable] [AttributeUsage(AttributeTargets.Class, Inherited ...

  2. 【Python学习之五】高级特性4(切片、迭代、列表生成器、生成器、迭代器)

    4.生成器(generator) 通过列表生成式,我们可以直接创建一个列表.但是,受到内存限制,列表容量肯定是有限的.如果列表元素可以按照某种算法推算出来,那我们是否可以在循环的过程中不断推算出后续的 ...

  3. 快速排序和快速选择(quickSort and quickSelect)算法

    排序算法:快速排序(quicksort)递归与非递归算法 TopK问题:快速选择(quickSelect)算法 import java.util.*; import java.lang.*; publ ...

  4. Ubuntu下kaldi安装

    该文章为博主原创,如若转载请注明出处:https://www.cnblogs.com/fengleixue/p/9482202.html 因公司业务需要需使用kaldi语音识别工具,现将kaldi环境 ...

  5. LeetCode939

    问题:最小面积矩形 给定在 xy 平面上的一组点,确定由这些点组成的矩形的最小面积,其中矩形的边平行于 x 轴和 y 轴. 如果没有任何矩形,就返回 0. 示例 1: 输入:[[1,1],[1,3], ...

  6. 【mysql】【转发】Cannot proceed because system tables used by Event Scheduler were found damaged at server start

    本地:mac 10.12.3  mysql 5.6   远程:linux 7.3    mysql 5.7.18.  (远程数据库yum安装,又5.6升级到5.7)   步骤:从本地数据库导出数据到远 ...

  7. 设置ubuntu12.04的dasher-自动隐藏,左上角

    点击右上角的齿轮,--> “system setting”--“Appearance” 在“Look”标签中: Theme:Ambiance Launch icon size :32 选择桌面背 ...

  8. 持续化集成Jenkins的系统配置

    最近在研究selenium2自动化测试,用到持续化集成jenkins.由于之前仅限于使用,而没有真正动手配置过,所以现在学习从零开始,搭建持续化集成,故而有了这篇博客. 先介绍一下项目持续集成测试,这 ...

  9. Python虚拟机之异常控制流(四)

    Python虚拟机中的异常控制流 先前,我们分别介绍了Python虚拟机之if控制流(一).Python虚拟机之for循环控制流(二)和Python虚拟机之while循环控制结构(三).这一章,我们来 ...

  10. 简单配置.htaccess就可以实现的10个功能

    http://bbs.itcast.cn/thread-25990-1-1.html?xhw 1. 反盗链那些盗用了你的内容,还不愿意自己存储图片的网站是很常见的.你可以通过以下配置来放置别人盗用你的 ...