[USACO1.1]坏掉的项链Broken Necklace

22892 破碎的项链

方法一:很容易想到枚举断点,再分别两头找,但是要注意很多细节

#include<iostream>
#include<string>
#include<cstdio>
using namespace std;
string s;
int n,l,r,ll,rr,tmp,ans;
inline int calc(int x) {
ll=s[x],rr=s[x+1],l=x-1,r=x+2;
if (rr=='w') {//如果是w,需分类讨论(如10 rwrwbwrwrw,答案为10,去掉后输出9)
rr='r',tmp=x+2;
while((s[tmp]=='w' || s[tmp]==rr) && tmp<x+n) tmp++;
rr='b';
}
while((s[l]=='w' || s[l]==ll) && l>x-n) l--;
while((s[r]=='w' || s[r]==rr) && r<x+n) r++;
return max(r,tmp)-l-1;
}
int main() {
cin>>n>>s;
s=s+s+s;
for (int i=n; i<n+n; i++)//复制了三段,从中间一段枚举断点
if (s[i]!=s[i+1] && s[i]!='w')//当s[i]==s[i+1]时,在i+1计算比在i更优
ans=max(ans,calc(i));
if (s[n+n-1]==s[n+n]) ans=max(ans,calc(n+n-1));//如果都是同一颜色,则最后一个答案没有计算(如3 rrr,去掉min答案就变成0)
printf("%d",min(ans,n));//如果都是同一颜色,则结果不应超过n,(如3 rrr,去掉min答案就变成5)
}

方法二:一边做一边统计答案(思路来自这个博客

#include<cstring>
#include<cstdio>
#include<iostream>
using namespace std;
char s[700],c;
int n,l,r,w,ans;
/*
l:左段长度,r:右段长度
w:连续w段的长度
c:当前段的颜色
*/
int main() {
scanf("%d%s",&n,s);
memcpy(s+n,s,n);
for (int i=0; i<n<<1; i++)
if (s[i]=='w') w++,r++;
else if (s[i]==c) w=0,r++;
else ans=max(ans,l+r),l=r-w,r=w+1,w=0,c=s[i];
//这里不能写为l=r,r=1,要把w段给右边,这样在下次修改答案时l更大
//如:bwrrb,遇到第一个r时应当把w给右边,即l=r-w=1,r=w+1=2,这样到第二个b时l更新为3
//而如果用l=r=2,r=1, 第二个b时l更新为2(把开头的w舍去了)
printf("%d",min(max(ans,l+r),n));
}

方法三:dp(思路来自这个博客

#include<cstdio>
#include<iostream>
#include<cstring>
using namespace std;
int n,lb[701],lr[701],rb[701],rr[701],ans;//l[i]不包括i,r[i]包括i
char s[701];
int main() {
scanf("%d%s",&n,s),memcpy(s+n,s,n),n<<=1;
for (int i=1; i<n; i++)
if (s[i-1]=='b') lb[i]=lb[i-1]+1;
else if (s[i-1]=='r') lr[i]=lr[i-1]+1;
else lb[i]=lb[i-1]+1,lr[i]=lr[i-1]+1;
for (int i=n-2; i>=0; i--)
if (s[i]=='b') rb[i]=rb[i+1]+1;
else if (s[i]=='r') rr[i]=rr[i+1]+1;
else rb[i]=rb[i+1]+1,rr[i]=rr[i+1]+1;
for (int i=0; i<n; i++)
ans=max(ans,max(lb[i],lr[i])+max(rb[i],rr[i]));
printf("%d",min(ans,n>>1));
}

题解 P1203 【[USACO1.1]坏掉的项链Broken Necklace】的更多相关文章

  1. P1203 [USACO1.1]坏掉的项链Broken Necklace

    P1203 [USACO1.1]坏掉的项链Broken Necklace不错的断环为链的模拟题,开成三倍,有很多细节要考虑,比如总长度要<=n,开头第一个是w等等. #include<bi ...

  2. 洛谷 P1203 [USACO1.1]坏掉的项链Broken Necklace

    坏掉的项链Broken Necklace 难度:★ Code: #include <iostream> #include <cstdio> #include <cstri ...

  3. 洛谷P1203 [USACO1.1]坏掉的项链Broken Necklace

    题目描述 你有一条由N个红色的,白色的,或蓝色的珠子组成的项链(3<=N<=350),珠子是随意安排的. 这里是 n=29 的二个例子: 第一和第二个珠子在图片中已经被作记号. 图片 A ...

  4. AC日记——[USACO1.1]坏掉的项链Broken Necklace 洛谷 P1203

    题目描述 你有一条由N个红色的,白色的,或蓝色的珠子组成的项链(3<=N<=350),珠子是随意安排的. 这里是 n=29 的二个例子: 第一和第二个珠子在图片中已经被作记号. 图片 A ...

  5. [USACO1.1]坏掉的项链Broken Necklace

    题目描述 你有一条由N个红色的,白色的,或蓝色的珠子组成的项链(3<=N<=350),珠子是随意安排的. 这里是 n=29 的二个例子: 第一和第二个珠子在图片中已经被作记号. 图片 A ...

  6. 【P1203】 【USACO1.1】坏掉的项链Broken Necklace

    P1203 [USACO1.1]坏掉的项链Broken Necklace 题目描述 你有一条由N个红色的,白色的,或蓝色的珠子组成的项链(3<=N<=350),珠子是随意安排的. 这里是 ...

  7. [USACO1.1.4]坏掉的项链Broken Necklace

    P1203 [USACO1.1]坏掉的项链Broken Necklace 标签 搜索/枚举 USACO 难度 普及- 题目描述 你有一条由N个红色的,白色的,或蓝色的珠子组成的项链(3<=N&l ...

  8. USACO Training Section 1.1 坏掉的项链Broken Necklace

    题目描述 你有一条由N个红色的,白色的,或蓝色的珠子组成的项链(3<=N<=350),珠子是随意安排的. 这里是 n=29 的二个例子: 第一和第二个珠子在图片中已经被作记号. 图片 A ...

  9. Broken Necklace 坏掉的项链 USACO 模拟(易错)

    1004: 1.1.4Broken Necklace 坏掉的项链 时间限制: 1 Sec  内存限制: 128 MB提交: 11  解决: 9[提交] [状态] [讨论版] [命题人:外部导入] 题目 ...

随机推荐

  1. 自然语言处理(1)-HMM隐马尔科夫模型基础概念(一)

    隐马尔科夫模型HMM 序言 文本序列标注是自然语言处理中非常重要的一环,我先接触到的是CRF(条件随机场模型)用于解决相关问题,因此希望能够对CRF有一个全面的理解,但是由于在学习过程中发现一个算法像 ...

  2. 剑指offer-面试题31-栈的压入弹出序列-栈

    #include<iostream> #include<string.h> #include<algorithm> #include<cmath> #i ...

  3. 剑指offer-面试题23-链表中环的入口节点-双指针

    /* 题目: 如果链表中包含环,如何找出环的入口? */ /* 思路: 双指针: 1.判断是否有环. fast指针一次2步,slow指针一次1步,当fast与slow相遇时,说明有环. 2.判断环路中 ...

  4. list=null和list.size=0的区别

    声明转载自:https://blog.csdn.net/iblade/article/details/50506398/ 转载自:https://blog.csdn.net/Hallelujah__/ ...

  5. 【15】ML项目流程与正交化

    结构化机器学习项目 一 ML项目流程 1,确立目标(确定开发/测试集 + 唯一最优化指标) 确定开发/测试集:开发/测试集应尽可能接近将来应用场景中的数据. 划分数据集:开发集和测试集大小足以评估模型 ...

  6. Java(三)String类

    一.String类初始化方法 1.初始化一个空字符串 String str=new String();//这里调用了String的无参构造方法 2.初始化一个有值的字符串 String str1=&q ...

  7. mysql如何让两个字段数据都不能重复?

    目录 场景 任务(需求) 行动(解决方案) 方案1:从代码层面解决(正确方案) 方案2:设置成两个唯一索引(正确方案) 方案3:删掉中间表,把从表的主键作为主表的外键,并将外键设置成唯一索引(正确方案 ...

  8. 【算法】用两个栈来实现一个队列,完成队列的Push和Pop操作。 队列中的元素为int类型。

    public class Solution { Stack<Integer> stack1 = new Stack<Integer>(); Stack<Integer&g ...

  9. 常用命令 在linux下

    1.拷贝某个目录及其下的所有的文件到另外一个目录 语法:cp -r <source directory name>/ <destination directory name>/ ...

  10. BZOJ4710: [Jsoi2011]分特产 组合数学 容斥原理

    题意:把M堆特产分给N个同学,要求每个同学至少分到一种特产,共有多少种分法? 把A个球分给B个人的分法种数:(插板法,假设A个球互不相同,依次插入,然后除以全排列去重) C(A,B+A) 把M堆特产分 ...