双指针_贪心_1921_D. Very Different Array

cpp 复制代码
#include<bits/stdc++.h>

using namespace std;

const int N=2e5+10;

int a[N],b[N];
bool flag[N];

void solve()
{
	int n,m;
	cin>>n>>m;
	
	for(int i=0;i<n;i++)
		cin>>a[i];
	for(int i=0;i<m;i++)
		cin>>b[i];
	
	sort(a,a+n);
	sort(b,b+m);
	
//	for(int i=0;i<n;i++)
//		cout<<a[i]<<" ";
//	cout<<endl;
//	for(int i=0;i<m;i++)
//		cout<<b[i]<<" ";
//	cout<<endl;
	
	int ans=0;
	int i=0,j=m-1;
//	for(int k=0;k<n;k++)
//	{
//		int x=b[i];
//		int y=b[j];
//		
//		x=abs(x-a[k]);
//		y=abs(y-a[k]);
//		
//		if(x>y&&i<=m-1&&flag[i]==false)
//		{
			cout<<i<<endl;
//			flag[i]=true;
//			i++;
//			ans+=x;
//		}
//		else if(x<=y&&j>=0&&flag[j]==false)
//		{
//			flag[j]=true;
//			j--;
//			ans+=y;
//		}
//	}
	
//	for(int p=0,q=n-1;p<=n-1&&q>=0;p++,q--)
//	{
//		int x=abs(a[p]-b[j]);
//		int y=abs(a[q]-b[i]);
//		
//		if(x>y&&flag[j]==false&&j>=0)
//		{
//			flag[j]=true;
//			j--;
//			ans+=x;
//		}
//		else if(x<=y&&flag[i]==false&&i<=m-1)
//		{
//			flag[i]=true;
//			i++;
//			ans+=y;
//		}
//	}
	
//	int cnt=0;
//	for(int k=0;k<n&&cnt<n;k++)
//	{
//		int a1=abs(a[k]-b[i]);
//		int a2=abs(a[n-1-k]-b[i]);
//		int a3=abs(a[k]-b[j]);
//		int a4=abs(a[n-1-k]-b[j]);
//		
//		if(a1>=a2&&a1>=a3&&a1>=a4&&flag[i]==false&&flag_a[k]==false&&i<=n-1)
//		{
//			flag[i]=true;
//			flag_a[k]=true;
//			i++;
//			ans+=a1;
//			cnt++;
//		}
//		else if(a2>=a1&&a2>=a3&&a2>=a4&&flag[i]==false&&flag_a[n-1-k]==false&&i<=n-1)
//		{
//			flag[i]=true;
//			flag_a[n-1-k]=true;
//			i++;
//			ans+=a2;
//			cnt++;
//		}
//		else if(a3>=a1&&a3>=a2&&a3>=a4&&flag[j]==false&&flag_a[k]==false&&j>=0)
//		{
//			flag[j]=true;
//			flag_a[k]=true;
//			j--;
//			ans+=a3;
//			cnt++;
//		}
//		else if(a4>=a1&&a4>=a2&&a4>=a3&&flag[j]==false&&flag_a[n-1-k]==false&&j>=0)
//		{
//			flag[j]=true;
//			flag_a[n-1-k]=true;
//			j--;
//			ans+=a4;
//			cnt++;
//		}
//	}
	
	int p=0,q=n-1;
	while(p!=q)
	{
		int a1=abs(a[p]-b[i]);
		int a2=abs(a[q]-b[i]);
		int a3=abs(a[p]-b[j]);
		int a4=abs(a[q]-b[j]);
		
		if(a1>=a2&&a1>=a3&&a1>=a4&&flag[i]==false)
		{
			flag[i]=true;
			i++;
			ans+=a1;
			p++;
		}
		else if(a2>=a1&&a2>=a3&&a2>=a4&&flag[i]==false)
		{
			flag[i]=true;
			i++;
			ans+=a2;
			q--;
		}
		else if(a3>=a1&&a3>=a2&&a3>=a4&&flag[j]==false)
		{
			flag[j]=true;
			j--;
			ans+=a3;
			p++;
		}
		else if(a4>=a1&&a4>=a2&&a4>=a3&&flag[j]==false)
		{
			flag[j]=true;
			j--;
			ans+=a4;
			q--;
		}
	}
	
	cout<<ans<<endl;
	memset(flag,false,sizeof flag);
//	memset(flag_a,false,sizeof flag_a);
}

int main()
{
	ios::sync_with_stdio(false);
	cin.tie(nullptr);
	
	int t;
	cin>>t;
	
	while(t--)
		solve();
	
	return 0;
}

尝试了几个版本的双指针,都无法通过第一个样例

思路是给两个数组排序,然后给两个数组使用双指针,贪心策略维护最大值,累加贡献,最后输出答案

cpp 复制代码
#include<bits/stdc++.h>

using namespace std;

const int N=2e5+10;

int a[N],b[N];

void solve()
{
	int n,m;
	cin>>n>>m;
	
	for(int i=0;i<n;i++)
		cin>>a[i];
	for(int i=0;i<m;i++)
		cin>>b[i];
	
	sort(a,a+n);
	sort(b,b+m);
	
	long long ans=0;
	int al=0,ar=n-1,bl=0,br=m-1;
	while(al<=ar&&bl<=br)
	{
		int a1=abs(a[al]-b[bl]);
		int a2=abs(a[ar]-b[bl]);
		int a3=abs(a[al]-b[br]);
		int a4=abs(a[ar]-b[br]);
		
		int temp=max({a1,a2,a3,a4});
		ans+=temp;
		
		if(temp==a1)
			al++,bl++;
		else if(temp==a2)
			ar--,bl++;
		else if(temp==a3)
			al++,br--;
		else if(temp==a4)
			ar--,br--;
	}
	cout<<ans<<endl;
}

int main()
{
	ios::sync_with_stdio(false);
	cin.tie(nullptr);
	
	int t;
	cin>>t;
	
	while(t--)
		solve();
	
	return 0;
}

还是这个思路,简化了一下过了

思路其实应该是可以了,主要是代码的一些细节没有处理好,像下面那样写就可以了

注意答案的数据范围比较大,需要使用 long long

相关推荐
智驱力人工智能3 小时前
工厂智慧设备检测:多模态算法提升工业安全阈值
人工智能·算法·安全·边缘计算·智慧工厂·智能巡航·工厂设备检测
R-G-B5 小时前
【15】OpenCV C++实战篇——fitEllipse椭圆拟合、 Ellipse()画椭圆
c++·人工智能·opencv·fitellipse椭圆拟合·ellipse画椭圆·椭圆拟合·绘制椭圆
2501_924731475 小时前
城市路口识别准确率↑31%!陌讯时空建模算法在交通拥堵识别中的突破
人工智能·算法·目标检测·计算机视觉·目标跟踪
熬了夜的程序员6 小时前
【华为机试】208. 实现 Trie (前缀树)
数据结构·算法·华为od·华为
界面开发小八哥7 小时前
MFC扩展库BCGControlBar Pro v36.2:MSAA和CodedUI测试升级
c++·mfc·bcg·界面控件
小O的算法实验室8 小时前
2024年ESWA SCI1区TOP,自适应种群分配和变异选择差分进化算法iDE-APAMS,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
不吃洋葱.9 小时前
左子树之和
算法
金融小师妹9 小时前
基于AI量化模型的比特币周期重构:传统四年规律是否被算法因子打破?
大数据·人工智能·算法
极客BIM工作室10 小时前
C++ 限制类对象数量的技巧与实践
开发语言·javascript·c++
郝学胜-神的一滴10 小时前
Horse3D引擎研发笔记(四):在QtOpenGL下仿three.js,封装EBO绘制四边形
c++·3d·unity·游戏引擎·godot·图形渲染·虚幻