B. Yet Another Palindrome Problem-----------思维

在这里插入图片描述
在这里插入图片描述

题意:
给定一个字符串s,问你是否有长度大于等于3的回文串

解析:
只要找两个相同的数之间的距离>1 即可


#include<bits/stdc++.h>
using namespace std;
const int N=50005;
map<int,int> v;
int x;
int main()
{
	int t;
	scanf("%d",&t);
	while(t--)
	{
		int n;
		v.clear();
		scanf("%d",&n);
		int f=0;
		for(int i=1;i<=n;i++)
		{
			cin>>x;
			//cout<<x<<endl;
			if(v[x]==0)
			{
				v[x]=i;
			}
			else 
			{
				int p=i-v[x];
				if(p>1) f=1;
			}
		}
		if(f==1) cout<<"YES"<<endl;
		else cout<<"NO"<<endl;
	}
}
发布了491 篇原创文章 · 获赞 11 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/qq_43690454/article/details/104858232