双指针问题5(c++)

概念

双指针,顾名思义,就是用两个指针解决问题

有些问题用单指针会出现超时等问题 ,这时就需要用到双指针

双指针由两个指针组成 ,一般是左右指针 ,或前后指针

通过两个指针配合变化,用更短的时间高效解决问题

题目

(续上一篇,如需了解上一篇题目,请移步主页观看)

合并有序数组

cpp 复制代码
#include <bits/stdc++.h>
#define ll long long
using namespace std;
int la,lb,lab;
int a[20010],b[10010];

int main()
{
	cin>>la;
	for(int i = 1;i<=la;i++)
	{
		cin>>a[i];
	}
	cin>>lb;
	for(int i = 1;i<=lb;i++)
	{
		cin>>b[i];
	}
	lab = la+lb;
	int ai = la+1,bi = lb+1,abi = lab+1;
	while(ai>1&&bi>1)
	{
		if(a[ai-1]>b[bi-1]) a[--abi] = a[--ai];
		else a[--abi] = b[--bi];
	}
	while(bi>1) a[--abi] = b[--bi];
	for(int i = 1;i<=lab;i++) cout<<a[i]<<" ";
	return 0;
}

完美数列

cpp 复制代码
#include <bits/stdc++.h>
#define ll long long
using namespace std;
int n,p;
int a[10010];

int main()
{
	cin>>n>>p;
	for(int i = 1;i<=n;i++)
	{
		cin>>a[i];
	}
	sort(a+1,a+n+1);
	int fast = 0,slow = 1;
	int ma,mi;
	mi = a[slow];
	int mama = -999999999;
	while(fast<n)
	{
		while(fast<n)
		{
			ma = a[++fast];
			int x = mi*p;
			if(ma<=x) mama = max(mama,fast-slow+1);
			else break;
		}
		while(slow<fast)
		{
			mi = a[++slow];
			int x = mi*p;
			if(ma<=x)
			{
				mama = max(mama,fast-slow+1);
				break;
			}
		}
	}
	cout<<mama;
	return 0;
}

反转元音字母

cpp 复制代码
#include <bits/stdc++.h>
#define ll long long
using namespace std;
string a;
char yy[] = {'a','e','i','o','u'};

int main()
{
	cin>>a;
	int n = a.size();
	int l = 0,r = n-1;
	while(l<r)
	{
		bool lf = false;
		bool rf = false;
		for(int i = 0;i<5;i++)
		{
			if(a[l]==yy[i]) lf = true;
			if(a[r]==yy[i]) rf = true;
		}
		if(lf==false) l++;
		if(rf==false) r--;
		if(lf==true&&rf==true)
		{
			swap(a[l],a[r]);
			l++;
			r--;
		}
	}
	cout<<a;
	
	
	return 0;
}

验证回文串2

cpp 复制代码
#include <bits/stdc++.h>
#define ll long long
using namespace std;
string a;
int n;
bool chushi();
bool hou(int,int);
int main()
{
	cin>>a;
	n = a.size();
	if(chushi()==true) cout<<"true";
	else cout<<"false";
	return 0;
}
bool chushi()
{
	int l = 0,r = n-1;
	while(l<r)
	{
		if(a[l]==a[r]) l++,r--;
		else
		{
			if((hou(l+1,r)|hou(l,r-1))==true) return true;
			else return false;
		}
	}
	return true;
}
bool hou(int l,int r)
{
	while(l<r)
	{
		if(a[l]==a[r]) l++,r--;
		else return false;
	}
	return true;
}

最接近的三数之和

cpp 复制代码
#include <bits/stdc++.h>
#define ll long long
using namespace std;
int n,a[10010],target,misum,micha;

int main()
{
	micha = 999999999;
	cin>>n;
	for(int i = 1;i<=n;i++)
	{
		cin>>a[i];
	}
	cin>>target;
	sort(a+1,a+n+1);
	for(int i = 1;i<=n-2;i++)
	{
		int l = i+1,r = n;
		while(l<r)
		{
			int sum = a[l]+a[i]+a[r];
			int cha = sum-target;
			if(cha<0) cha = target-sum,l++;
			else r--;
			if(cha<micha)
			{
				micha = cha;
				misum = sum;
			}
		}
	}
	cout<<misum;
	
	return 0;
}
相关推荐
爱装代码的小瓶子12 小时前
算法【c++】二叉树搜索树转换成排序双向链表
c++·算法·链表
思成Codes12 小时前
数据结构:基础线段树——线段树系列(提供模板)
数据结构·算法
阳洞洞13 小时前
cmake中如何从include_directories中移除某个特定的头文件
c++·cmake
墨雪不会编程13 小时前
C++【string篇1遍历方式】:从零开始到熟悉使用string类
java·开发语言·c++
虾..14 小时前
Linux 简单日志程序
linux·运维·算法
Trent198514 小时前
影楼精修-眼镜祛反光算法详解
图像处理·人工智能·算法·计算机视觉·aigc
蓝色汪洋14 小时前
经典修路问题
开发语言·c++·算法
csuzhucong14 小时前
122魔方、123魔方
算法
Salt_072814 小时前
DAY 40 早停策略和模型权重的保存
人工智能·python·算法·机器学习
卜锦元15 小时前
Golang后端性能优化手册(第三章:代码层面性能优化)
开发语言·数据结构·后端·算法·性能优化·golang