Codeforces Round #503 (by SIS, Div. 2)-C. Elections

时间:2022-10-24 19:06:12

枚举每个获胜的可能的票数+按照花费排序

#include<iostream>
#include<stdio.h>
#include<string.h>
#include<algorithm>
#define ll long long
using namespace std;
struct node
{
int id,cost;
} a[];
bool cmp(node a,node b)
{
return a.cost<b.cost;
}
int g[];
int f[];
int main()
{
int n,m;
while(~scanf("%d%d",&n,&m))
{
ll sum=;
ll sum2=;
ll ans;
memset(f,,sizeof(f));
memset(g,,sizeof(g));
for (int i=; i<=n; i++)
{
scanf("%d%d",&a[i].id,&a[i].cost);
f[a[i].id]++;
}
sort(a+,a++n,cmp); for (int i=f[]; i<=n; i++) //枚举赢需要多少票数
{
sum2=;
ans=;
for (int j=; j<=m; j++)
{
if (f[j]>=i)
{
g[j]=(f[j]-i+);//必须降到比我少一票
sum2+=g[j];
}
else
{
g[j]=;
}
}
if (i-f[]<sum2)continue;//如果我最终的票数无法赢别人这个状态就是不满足的
sum2=i-f[]-sum2;//需要从票数比我低的人的那里买多少
for (int j=; j<=n; j++)
{
if (g[a[j].id]!=)
{
g[a[j].id]--;//比我高的票数减一
ans+=a[j].cost;
}
else
{
if (sum2!= && a[j].id!=)//如果我需要在比我的低的人那里买多少
{
sum2--;
ans+=a[j].cost;
}
}
}
sum=min(sum,ans);
}
cout<<sum<<endl;
}
return ;
}

Codeforces Round #503 (by SIS, Div. 2)-C. Elections的更多相关文章

  1. Codeforces Round &num;503 &lpar;by SIS&comma; Div&period; 2&rpar; C&period; Elections (暴力&plus;贪心)

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

  2. Codeforces Round &num;503 &lpar;by SIS&comma; Div&period; 2&rpar; C&period; Elections(枚举,暴力&rpar;

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

  3. Codeforces Round &num;503 &lpar;by SIS&comma; Div&period; 2&rpar; Solution

    从这里开始 题目列表 瞎扯 Problem A New Building for SIS Problem B Badge Problem C Elections Problem D The hat P ...

  4. Codeforces Round &num;503 &lpar;by SIS&comma; Div&period; 2&rpar;

    连接:http://codeforces.com/contest/1020 C.Elections 题型:你们说水题就水题吧...我没有做出来...get到了新的思路,不虚.好像还有用三分做的? KN ...

  5. Codeforces Round &num;503 &lpar;by SIS&comma; Div&period; 1&rpar;E&period; Raining season

    题意:给一棵树每条边有a,b两个值,给你一个m,表示从0到m-1,假设当前为i,那么每条边的权值是a*i+b,求该树任意两点的最大权值 题解:首先我们需要维护出(a,b)的凸壳,对于每个i在上面三分即 ...

  6. Codeforces Round &num;503 &lpar;by SIS&comma; Div&period; 2&rpar; D&period; The hat

    有图可以直观发现,如果一开始的pair(1,1+n/2)和pair(x, x+n/2)大小关系不同 那么中间必然存在一个答案 简单总结就是大小关系不同,中间就有答案 所以就可以使用二分 #includ ...

  7. Codeforces Round &num;503 &lpar;by SIS&comma; Div&period; 2&rpar;B 1020B Badge (拓扑)

    题目大意:每个同学可以指定一个人,然后构成一个有向图.1-n次查询,从某个人开始并放入一个东西,然后循环,直到碰到一个人已经放过了,就输出. 思路:直接模拟就可以了,O(n^2) 但是O(n)也可以实 ...

  8. Codeforces Round &num;503 &lpar;by SIS&comma; Div&period; 2&rpar; D&period; The hat -交互题,二分

    cf1020D 题意: 交互题目,在有限的询问中找到一个x,使得数列中的第x位和第(x+n/2)位的值大小相同.数列保证相邻的两个差值为1或-1: 思路: 构造函数f(x) = a[x] - a[x ...

  9. Codeforces Round &num;503 &lpar;by SIS&comma; Div&period; 2&rpar; E&period; Sergey&&num;39&semi;s problem

    E. Sergey's problem [题目描述] 给出一个n个点m条边的有向图,需要找到一个集合使得1.集合中的各点之间无无边相连2.集合外的点到集合内的点的最小距离小于等于2. [算法] 官方题 ...

随机推荐

  1. PHP 数据库连接工具类(MySQLI函数包装)

    ====================mysql===================== <?php class mysql { private $mysqli; private $resu ...

  2. 对JavaScript中异步同步机制以及线程深入了解

    今天在网上看到各种对Js异步同步单线程多线程的讨论 经过前辈们的洗礼 加上鄙人小小的理解 就来纸上谈兵一下吧~ Js本身就是单线程的 至于为什么Js是单线程的 那就要追溯到Js的历史了 总而言之 由于 ...

  3. extJs学习基础3 ajax与php交互

    extJs代码: <script src="build/ext-all.js"></script> <script src="build/p ...

  4. fedora 23如何实现 让root用户自动登录&quest;

    没想到很简单: 只是修改一个文件的一个地方: 修改: /etc/gdm/custom.conf文件, 将自动登录 启用为true, 然后自动登录的名字设为root 即可:

  5. Abdicate

    每次,打开背单词软件,背诵单词时,A打头的单词,第一个,永远会是 Abdicate,放弃,抛弃. 真是有意思. 想想在学习js高级程序设计一书时,一横心,决心手动输入书中出现过的每一个代码片段示例. ...

  6. PHP 学习笔记 (三)

    stream_context_create()函数的用法: $url = "http://www.someweb.com" $context = stream_context_cr ...

  7. 使用VB6读取数据库资源并发送邮件(原创)

    Private Sub Form_Load() Call conndb End Sub Private Function conndb() Dim cn As New ADODB.Connection ...

  8. js高级---本地对象、内置对象、宿主对象

    名词参考: 原生对象:也叫内部对象.本地对象.native object 内置对象:Build-in object 宿主对象:host object ECMA-262 定义: 原生对象:独立于宿主环境 ...

  9. scrapy 自定义图片路径保存,并存到数据库中

    scrapy中有个自带的pipeline工具,ImagesPipeline,可以专门用来储存图片到本地. 但默认储存地址无法配置,所以我们需要写一个自己的pipeline用于储存图片. 先分析一下我们 ...

  10. Windows10系统的Linux子系统中安装MySQL数据库心得

    后端开发童鞋们, 自己开发机用的是Windows系统电脑(台式机或笔记本), 而开发的程序和使用的数据库等要运行在Linux服务器上, 这种情况有木有? 提前声明: 本文并不讨论操作系统的比较, 以及 ...