CF1989C Two Movies 题解

CF1989C Two Movies

贪心。如果某人对两部电影评分不一样,显然取评分高的那一个。如果是 1011,那么显然取 1。如果是 01,显然取 0

接下来,讨论评分一样的情况。对于 00,取哪一个都没有影响,直接忽略。对于 11,我们记录这种人的个数,在处理完评分不一样的人之后统一处理。由于我们要使最小值最大,所以优先将这种人的增加评分给较小的一部电影。否则不会影响最小值,显然不优。

对于 11,同理,我们记录这种人的个数,在处理完评分不一样的人之后统一处理。由于我们要使最小值最大,所以优先将这种人的减少评分给较大的一部电影。否则会减小最小值,显然不优。

时间复杂度 O(n)

#include <bits/stdc++.h>
using namespace std;
long long t,n,a[300000],b[300000];
int main()
{
	scanf("%lld",&t);
	while(t--)
	   {
	   	long long x=0,y=0,pf=0,nf=0;
	   	scanf("%lld",&n);
	   	for(int i=1;i<=n;i++)scanf("%lld",&a[i]);
	   	for(int i=1;i<=n;i++)scanf("%lld",&b[i]);
	   	for(int i=1;i<=n;i++)
	   	    if(a[i]>b[i])x+=a[i];
	   	    else if(a[i]<b[i])y+=b[i];
	   	    else if(a[i]==1&&b[i]==1)pf++;
	   	    else if(a[i]==-1&&b[i]==-1)nf++;
	   	while(pf)
	   	   {
	   	   	if(x<=y)x++;
	   	   	else y++;
	   	   	pf--;
		   }
		while(nf)
	   	   {
	   	   	if(x>=y)x--;
	   	   	else y--;
	   	   	nf--;
		   }
		printf("%lld\n",min(x,y));
	   }
	return 0;
} 
posted @   w9095  阅读(2)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
· SQL Server 2025 AI相关能力初探
点击右上角即可分享
微信分享提示