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

题目描述

你有一条由N个红色的,白色的,或蓝色的珠子组成的项链(3<=N<=350),珠子是随意安排的。 这里是 n=29 的二个例子:



第一和第二个珠子在图片中已经被作记号。

图片 A 中的项链可以用下面的字符串表示:

brbrrrbbbrrrrrbrrbbrbbbbrrrrb

假如你要在一些点打破项链,展开成一条直线,然后从一端开始收集同颜色的珠子直到你遇到一个不同的颜色珠子,在另一端做同样的事(颜色可能与在这之前收集的不同)。

确定应该在哪里打破项链来收集到最大数目的珠子。

例如,在图片 A 中的项链中,在珠子 9 和珠子 10 或珠子 24 和珠子 25 之间打断项链可以收集到8个珠子。

白色珠子什么意思?

在一些项链中还包括白色的珠子(如图片B) 所示。

当收集珠子的时候,一个被遇到的白色珠子可以被当做红色也可以被当做蓝色。

表现含有白珠项链的字符串将会包括三个符号 r , b 和 w 。

写一个程序来确定从一条被给出的项链可以收集到的珠子最大数目。

输入输出格式 d 输入格式: 第 1 行: N, 珠子的数目

第 2 行: 一串长度为N的字符串, 每个字符是 r , b 或 w。

输出格式: 输入输出样例

输入样例#1:

  1. 29
  2. wwwbbrwrbrbrrbrbrwrwwrbwrwrrb
  3. 输出样例#1
  4. 11

题目思路

这一题可以用dp去写,但是我只能想到用暴力枚举(由于数据范围比较小)在每一个位置断开所能得到的珠子的最大数量,具体思路直接看代码吧

题解如下

  1. #include<iostream>
  2. using namespace std;
  3. const int Len = 355;
  4. struct Bead
  5. {
  6. int cnt;
  7. char color;
  8. }bead[Len];
  9. int main()
  10. {
  11. // freopen("T.txt","r",stdin);
  12. int pos = 0;
  13. int n;
  14. scanf("%d", &n);
  15. char ch;
  16. int cnt = 0;
  17. int last_ch = '@'; //对上一个初始化成一个特殊字符
  18. for(int i = 0; i < n; i ++) //统计连续相同颜色珠子的数量及颜色
  19. {
  20. cin>>ch;
  21. if(ch != last_ch)
  22. {
  23. bead[pos].cnt = cnt;
  24. bead[pos].color = last_ch;
  25. pos ++;
  26. cnt = 0;
  27. last_ch = ch;
  28. }
  29. cnt ++;
  30. }
  31. //对字符串最后一个连续相同的字符数量进行统计
  32. bead[0].color = bead[1].color;
  33. bead[pos].cnt = cnt;
  34. bead[pos ++].color = last_ch;
  35. int ans = 0,len = 0; //len 当前正在讨论从某个位置断开可以得到的最大珠子的数量
  36. for(int i = 2; i < pos; i ++) //遍历每一个位置进行讨论
  37. {
  38. if(bead[i].color == 'w')
  39. continue;
  40. int l_i = i - 2,r_i = i + 1; //l_i 从i - 2这个位置从右向左遍历,r_i从i+1 这个位置从左向右一个一个的判读
  41. r_i %= pos; //防止下标越界
  42. len = bead[i - 1].cnt + bead[i].cnt;
  43. int flag_w = 0; //是否i - 1 这个位置的珠子是白色的
  44. if(bead[i - 1].color == 'w') //如果是
  45. {
  46. flag_w = 1;
  47. bead[i - 1].color = bead[l_i].color; //把i-1这些白颜色的珠子变成 i - 2 位置的珠子的颜色
  48. }
  49. char l_co = bead[i - 1].color,r_co = bead[i].color; //l_co 挨着断开出左边珠子的颜色,r_co挨着断开出右边珠子的颜色
  50. //右边的长度判断
  51. while(true)
  52. {
  53. if(bead[r_i].color == r_co || bead[r_i].color == 'w')
  54. {
  55. len += bead[r_i].cnt;
  56. r_i ++;
  57. r_i %= pos;
  58. }
  59. else
  60. {
  61. break;
  62. }
  63. if(r_i == l_i) //在讨论右边长度的时候如果r_i == l_i 时候是没有讨论这个位置所代表的珠子颜色是否 l_co 或 r_co 颜色相同,这将在讨论 左边长度 的时候进行讨论
  64. {
  65. break;
  66. }
  67. }
  68. //左边长度的判读
  69. while(true)
  70. {
  71. if(bead[l_i].color == l_co || bead[l_i].color == 'w')
  72. {
  73. len += bead[l_i].cnt;
  74. l_i --;
  75. if(l_i < 0)
  76. l_i = pos - 1;
  77. }
  78. else
  79. {
  80. break;
  81. }
  82. if(l_i == r_i) //特判了
  83. {
  84. if(bead[l_i].color == 'w' || bead[l_i].color == l_co || bead[l_i].color == r_co)
  85. {
  86. len += bead[l_i].cnt;
  87. }
  88. break;
  89. }
  90. }
  91. if(flag_w) //如果i - 1 位置的颜色是白色,用完之后要把这个i - 1 位置所代表的珠子颜色变回来
  92. {
  93. bead[i - 1].color = 'w';
  94. }
  95. ans = max(ans , len);
  96. }
  97. if(ans == 0) //特殊情况讨论,如果所给珠子串全是 ‘w’
  98. {
  99. ans = n;
  100. }
  101. printf("%d",ans);
  102. return 0;
  103. }

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

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

  3. 题解 P1203 【[USACO1.1]坏掉的项链Broken Necklace】

    [USACO1.1]坏掉的项链Broken Necklace 22892 破碎的项链 方法一:很容易想到枚举断点,再分别两头找,但是要注意很多细节 #include<iostream> # ...

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

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

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

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

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

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

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

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

  8. [LuoguP1203][USACO1.1]P1203 Broken Necklace

    Solution 这道题数据规模奇小,因此大部分人都使用了暴力搜索的方法,这也是我一开始的想法. 对于 100100%100 的数据,3≤n≤3503≤n≤3503≤n≤350 的确可以如此,但暴力搜 ...

  9. 【USACO1.1】Broken Necklace

    题意 一个环形项链,有rbw三种珠子,r代表red,b代表blue,w代表white,从任意一个位置断开,两端分别取珠子,同一端取的珠子要相同颜色,w可以染成想要的颜色,即既可当作r也可以当作b,求最 ...

随机推荐

  1. blender 2.8 [学习笔记-04] 编辑模式-网格拆分

    在编辑模式下

  2. 峰哥说技术: 05-Spring Boot条件注解注解

    Spring Boot深度课程系列 峰哥说技术—2020庚子年重磅推出.战胜病毒.我们在行动 05 峰哥说技术  Spring Boot条件注解 @EnableAutoConfiguration开启自 ...

  3. es6的解构函数

    话说,解构无处不在啊,鄙人自从用了vue写项目以来,总是遇到各路大神莫名其妙的写法,然并未出任何错,查之,然解构也,呜呼哀哉,进而习之. 解构(Destructuring):是将一个数据结构分解为更小 ...

  4. Java自学路线图之Java系统自学

    Java自学不是一朝一夕的事情.可以采用"懒开始"的方法,但是必须要坚持下去,才能真正自学Java掌握编程技术.那些企图学几天去包装一下找工作的,请绕道.如果你下定决心自学Java ...

  5. MATLAB中的Regex

    regexprep——用于对字符串进行查找并替换. regexp Definition: 用于对字符串进行查找,大小写敏感. startIndex = regexp(str,expression) 返 ...

  6. cooke和session

    一.装饰器要加入funtools.wrap装饰 保留函数的元数据(函数名/注释) 1.装饰器 def wrapper(f): def inner(*args,**kwargs): return f(* ...

  7. Yaml文件,超详细讲解

    YAML文件简单介绍 YAML 是一种可读性非常高,与程序语言数据结构非常接近.同时具备丰富的表达能力和可扩展性,并且易于使用的数据标记语言. YAML全称其实是"YAML Ain't a ...

  8. 【TIJ4】第四章全部习题

    第四章 没啥好说的...... 4.1 package ex0401; //[4.1]写一个程序打印从1到100的值 public class PrintOneToHundred { public s ...

  9. 3D游戏中各种空间变换到底是怎么回事

    每一个游戏可以呈现炫丽效果的背后,需要进行一系列的复杂计算,同时也伴随着各种各样的顶点空间变换.渲染游戏的过程可以理解成是把一个个顶点经过层层处理最终转化到屏幕上的过程,本文就旨在说明,顶点是经过了哪 ...

  10. java基础-Map

    简介 Map是一种接口,实现类有 hashMap SortedMap是继承自Map的接口,实现类为TreeMap,在内部会对Key进行排序 遍历Map 使用for each循环遍历Map实例的keyS ...