坏掉的项链Broken Necklace
Description
你有一条由N个红色的,白色的,或蓝色的珠子组成的项链(3<=N<=350),珠子是随意安排的。 这里是 n=29 的二个例子:
第一和第二个珠子在图片中已经被作记号。 图片 A 中的项链可以用下面的字符串表示:
brbrrrbbbrrrrrbrrbbrbbbbrrrrb
假如你要在一些点打破项链,展开成一条直线,然后从一端开始收集同颜色的珠子直到你遇到一个不同的颜色珠子,在另一端做同样的事(颜色可能与在这之前收集的不同)。 确定应该在哪里打破项链来收集到最大数目的珠子。
例如,在图片 A 中的项链中,在珠子 9 和珠子 10 或珠子 24 和珠子 25 之间打断项链可以收集到8个珠子。 白色珠子什么意思? 在一些项链中还包括白色的珠子(如图片B) 所示。 当收集珠子的时候,一个被遇到的白色珠子可以被当做红色也可以被当做蓝色。 表现含有白珠项链的字符串将会包括三个符号 r , b 和 w 。 写一个程序来确定从一条被给出的项链可以收集到的珠子最大数目。
Input
第 1 行: N, 珠子的数目
第 2 行: 一串长度为N的字符串, 每个字符是 r , b 或 w。
Output
输出一行一个整数,表示从给出的项链中可以收集到的珠子的最大数量。
Sample Input
29
wwwbbrwrbrbrrbrbrwrwwrbwrwrrb
Sample Output
11
HINT
50%的数据,
100%的数据,
思路
嗯,一道简单的模拟题
先将数组复制一份连在后面 , 防样例 哈!这是一个环,没想到吧!
再循环将相邻两点切开 , 分别左右判断 , 最后累加
注:如果全部都能收集,则输出总数 , 而不是 那个更大的数
Code
严禁抄袭
#include <bits/stdc++.h>
using namespace std; //blue 2 ;red 3; 6
#define max(a, b) a > b ? a : b
#define min(a, b) a < b ? a : b
int n;
int a[1001];
char c;
int ans;
inline int js(int x)
{
int l = x, r = x + 1;
int la = a[l];
int ra = a[r];
if (a[l] == 3)
{
la = a[l - 1];
}
if (a[r] == 3)
{
ra = a[r - 1];
}
int ans = 0;
while (l >= 1)
{
if (a[l] == la || a[l] == 3)
{
ans++;
}
else
break;
l--;
}
while (r <= 2 * n)
{
if (a[r] == ra || a[r] == 3)
{
ans++;
}
else
break;
r++;
}
//cout<<ls<<" "<<rs<<endl;
return ans;
}
signed main()
{
cin >> n;
for (int i = 1; i <= n; i++)
{
cin >> c;
if (c == 'b')
{
a[i] = 1;
}
if (c == 'r')
{
a[i] = 2;
}
if (c == 'w')
{
a[i] = 3;
}
}
for (int i = 1; i <= n; i++)
{
a[n + i] = a[i];
}
for (int i = 1; i <= 2 * n; i++)
{
int op = js(i);
ans = max(ans, op);
}
ans = min(ans, n);
cout << ans << endl;
}
本文来自博客园,作者:蒟蒻orz,转载请注明原文链接:https://www.cnblogs.com/orzz/p/18122195