POJ 2159

本文介绍了一种用于比较两个字符串中字符连续重复次数的算法。该算法首先对输入字符串进行预处理,统计每个字符的连续出现次数,并将其存入频率向量。之后,通过排序并逐个比较两个字符串的频率向量,来判断这两个字符串是否具有相同的字符重复规律。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include<iostream>
#include<algorithm>
#include<vector>
#include<string>
using namespace std;
void countfreq(string s,vector<int>& freq){
	int len=s.size(),count=1;
	for(int i=1;i<len;++i){
		if(s[i]==s[i-1]){
			++count;
		}
		else{
			freq.push_back(count);
			count=1;
		}
	}
	freq.push_back(count);
}
bool cmp(int a,int b)
{
    return a>b;
}
int main(){
	string a,b,c;
	cin>>a>>b;
	int len=a.size();
	if(len==1){
		cout<<"YES";
		return 0;
	}
	sort(&a[0],&a[len]);//
	sort(&b[0],&b[len]);//
	//cout<<a<<endl<<b<<endl;
	vector<int> afreq;
	vector<int> bfreq;
	countfreq(a,afreq);
	countfreq(b,bfreq);
	if(afreq.size()!=bfreq.size()){
		cout<<"NO";
		return 0;
	}
	//cout<<afreq.size()<<endl;
	len=afreq.size();

	
	sort(&afreq[0],&afreq[len],cmp);//
	sort(&bfreq[0],&bfreq[len],cmp);//
	
	for(int i=0;i<len;++i){
		//cout<<afreq[i]<<" "<<bfreq[i]<<endl;
		if(afreq[i]!=bfreq[i]){
			cout<<"NO";
			return 0;
		}
	}
	/*vector<vector<int> > fluency;
	fluency.push_back({26});//
	
	int table[26]={0};
	for(int i=0;i<len;++i){
		++table[a[i]-'A'];
	}
	
	int max=0;
	for(int i=0;i<26;++i){
		fluency[]
		if(table[i]>max)
			max=table[i];
	}
	if(max==1)*/
	cout<<"YES";
	return 0;
}

上面只统计频次,好像不够严谨。最后一部分改成下面,不过,WA

	
	for(int i=0,j=0;i<len;++i,++j){
		j%=len;
		if(afreq[i]!=bfreq[j]){
			int k=j+1;
			k%=len;
			while((afreq[i]!=bfreq[k])&&(k!=j)){
				++k;
				k%=len;
			}
			if(k==j){
				cout<<"NO";
				return 0;
			}
			else{
				j=k;
			}
		}
	}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值