zoj3715 Kindergarten Election 【枚举+贪心】
2016-04-27 18:08
621 查看
不枚举要几票获胜根本想不同。
枚举获胜需要的票数(最少是2),然后自己这也票投给谁都没有影响。
枚举获胜需要的票数(最少是2),然后自己这也票投给谁都没有影响。
#include<bits/stdc++.h> using namespace std; struct node { int f,c,id; } p[1024],u[1024]; int cmp1(node a,node b) { if(a.f==b.f) return a.c<b.c; return a.f<b.f; } int cmp2(node a,node b) { return a.c<b.c; } int main() { int _,n,v[1024],use[1024],ans,tmp,num,cnt; scanf("%d",&_); while(_--) { scanf("%d",&n); memset(v,0,sizeof(v)); for(int i=2; i<=n; i++) { scanf("%d",&p[i].f); p[i].id=i; v[p[i].f]++; } for(int i=2; i<=n; i++) scanf("%d",&p[i].c); sort(p+2,p+1+n,cmp1); for(int i=2; i<=n; i++) u[i]=p[i]; sort(u+2,u+1+n,cmp2); int ans=0x7fffffff; for(int i=n; i>=max(2,v[1]); i--) { tmp=0; num=v[1]; memset(use,0,sizeof(use)); for(int j=2; j<=n; j++) { if(v[j]>i-1) { int cnt=v[j]-i+1; for(int k=2; k<=n; k++) { if(p[k].f!=j) continue; use[p[k].id]=1; tmp+=p[k].c; num++; cnt--; if(cnt==0) break; } } } if(num<i) { for(int k=2; k<=n;k++) { if(num>=i) break; if(u[k].f==1||use[u[k].id]==1) continue; tmp+=u[k].c; num++; } } ans=min(ans,tmp); } printf("%d\n",ans); } return 0; }
相关文章推荐
- JavaScript 最佳实践
- JavaScript 事件
- Android Button及TextView动态变换颜色
- 【排序算法】简单选择排序(java实现)
- java的自动装箱和自动拆箱
- java中接口与抽象类的区别
- SDK和API的区别?
- linux内存/cpu利用率 引出vmstat命令 free命令
- Cookie与Session的区别
- Android反编译
- Javascript 函数表达式
- GCD使用经验与技巧浅谈
- Android Shape自定义纯色圆角按钮
- elasticsearch中节点都启动但是无法形成集群问题
- java的native方法
- mysql服务器查询慢原因分析方法
- 调用grails领域类save方法没反应,不成功问题
- 练习3-A
- 团队绩效考核表
- 团队作业(五)