双指针问题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;
}
相关推荐
fie888920 小时前
MATLAB有限元框架程序
python·算法·matlab
小郭团队20 小时前
1_5_五段式SVPWM (传统算法反正切+DPWM1)算法理论与 MATLAB 实现详解
人工智能·嵌入式硬件·算法·dsp开发
思成Codes21 小时前
ACM训练:接雨水3.0——动态接雨水
数据结构·算法
alphaTao21 小时前
LeetCode 每日一题 2026/1/12-2026/1/18
python·算法·leetcode
sin_hielo21 小时前
leetcode 2943
数据结构·算法·leetcode
Snow_day.21 小时前
有关平衡树
数据结构·算法·贪心算法·动态规划·图论
Hcoco_me1 天前
大模型面试题75:讲解一下GRPO的数据回放
人工智能·深度学习·算法·机器学习·vllm
Xの哲學1 天前
Linux设备驱动模型深度解剖: 从设计哲学到实战演练
linux·服务器·网络·算法·边缘计算
明洞日记1 天前
【CUDA手册002】CUDA 基础执行模型:写出第一个正确的 Kernel
c++·图像处理·算法·ai·图形渲染·gpu·cuda
企业对冲系统官1 天前
基差风险管理系统集成说明与接口规范
大数据·运维·python·算法·区块链·github