双指针问题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;
}
相关推荐
倦王2 分钟前
力扣日刷47
算法·leetcode·职场和发展
MicroTech20255 分钟前
突破量子数据加载瓶颈,MLGO微算法科技推出面向大规模量子计算的分治态制备技术
科技·算法·量子计算
码王吴彦祖7 分钟前
顶象 AC 纯算法迁移实战:从补环境到纯算的完整拆解
java·前端·算法
SccTsAxR11 分钟前
算法基石:手撕离散化、递归与分治
c++·经验分享·笔记·算法
wuweijianlove12 分钟前
算法测试中的数据规模与时间复杂度匹配的技术4
算法
Q741_14737 分钟前
每日一题 力扣 3655. 区间乘法查询后的异或 II 模拟 分治 乘法差分法 快速幂 C++ 题解
c++·算法·leetcode·模拟·快速幂·分治·差分法
The_Ticker37 分钟前
印度股票实时行情API(低成本方案)
python·websocket·算法·金融·区块链
夏乌_Wx42 分钟前
剑指offer | 2.4数据结构相关题目
数据结构·c++·算法·剑指offer·c/c++
米啦啦.43 分钟前
C+类的友元与静态成员函数,类模板
c++·友元·类模板
超绝振刀怪1 小时前
【C++可变模板参数】
开发语言·c++·可变模板参数