解题思路:

题目也水,数据也水

注意事项:

注意循环终止条件,不要死循环了

参考代码:

#define _CRT_SECURE_NO_WARNINGS

#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
#include <stdio.h>
#define N 10000

using namespace std;

string necklace;
vector<int> ansSet;

int scanLeft(int startPos, int len)
{
	int totalLen = 0;
	int i = (startPos + len - 1) % len;
	int origI = i;
	bool first = true;
	bool setColor = false;
	char strColor = 0;
	while ((i != origI && !first) || first)
	{
		if (first)
			first = false;
		
		//颜色已决
		if (setColor)
		{
			if (necklace[i] == 'w' || necklace[i] == strColor)
				totalLen += 1;
			else
				break;
		}
		else
		{
			if (necklace[i] != 'w')
			{
				strColor = necklace[i];
				setColor = true;
			}
			totalLen += 1;
		}
		i = (i + len - 1) % len;
	}
	return totalLen;
}

int scanRight(int startPos, int len)
{
	int totalLen = 0;
	int i = (startPos + len) % len;
	bool first = true;
	bool setColor = false;
	char strColor = 0;

	while ((i != startPos && !first) || first)
	{
		if (first)
			first = false;
		//颜色已决
		if (setColor)
		{
			if (necklace[i] == 'w' || necklace[i] == strColor)
				totalLen += 1;
			else
				break;
		}
		else
		{
			if (necklace[i] != 'w')
			{
				strColor = necklace[i];
				setColor = true;
			}
			totalLen += 1;
		}
		i = (i + len + 1) % len;
	}
	return totalLen;
}

int solve()
{
	int len = necklace.length();
	int leftLen = 0, rightLen = 0;
	for (int i = 0; i < len; i++)
	{
		leftLen = scanLeft(i, len);
		rightLen = scanRight(i, len);
		ansSet.push_back(leftLen + rightLen);
	}
	return *max_element(ansSet.begin(), ansSet.end());
}

int main(int argc, char** argv)
{
	cin >> necklace;
	cout << solve() << endl;
	return 0;
}


附赠官方标答:

#include <stdio.h>
#include <string.h>
#include <ctype.h>
#include <string>
#include <map>
#include <set>
#include <vector>
using namespace std;
int len;
int getnum(string& s)
{
	int res = 0, i=0;
	while (s[i] == 'w')
	{
		i++;
		if (i==len)
			return i;
	}
	res = i+1;
	char t = s[i];
	++i;
	while ((s[i]==t ||s[i]=='w')&& s[i] != 0)
	{
		++i;
		res++;
	}
	if (res == len)
		return res;
	i = len-1;
	while (s[i] == 'w')
	{
		res++;
		--i;
	}
	res++;
	t = s[i];
	--i;
	while (i>=0 && (s[i]==t || s[i]=='w'))
	{
		res++;
		--i;
	}
	if (res > len)
		res = len;
	return res;
} 

int main()
{
	char str[110];
	scanf("%s", str);
	len = strlen(str);
	string s;
	int sum = 0, t;
	for (int i=0; i<len; ++i)
	{
		s = &str[i];
		for (int j=0; j<i; ++j)
		{
			s += str[j];
		}
		t = getnum(s);
		if (t > sum)
		{
			sum = t;
		}
	}
	printf("%d\n", sum);
	return 0;
}


点赞(1)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论