试题 算法提高 项链

资源限制
时间限制:1.0s 内存限制:512.0MB
问题描述
  由 n(1≤n≤100)  个珠子组成的一个项链,珠子有红、蓝、白三种颜色,各种颜色的珠子的安排顺序由键盘输入的字符串任意给定。蓝色用小写字母b表示,红色用小写字母r表示,  白色用小写字母w表示.

假定从项链的某处将其剪断,把它摆成一条直线。先从左端向右收集同色珠子,遇到第一个异色珠子时停止.  收集过程中, 白色是一种特殊颜色, 既可以看成红色也可以看成蓝色。然后再从剩余珠子的右端向左重复上述过程。

例如:对下图一所示的项链, 如果从图一中标记的位置0处剪断,  则按顺时针顺序得到wbbbwwrrbwbrrwb(如图二所示)。这时从左端开始收集可以得到wbbbww,  共6个珠子;然后从剩余珠子右端开始收集得到wb,共2个珠子。这种剪法共可收集到6+2=8个珠子。 如果从图一中标记的位置4处剪断,  则按顺时针顺序得到wwrrbwbrrwbwbbb(如图二所示)。这时从左端收集可以得到wwrr,共4个珠子;然后从剩余珠子右端收集可以得到wbwbbb,共6个珠子。这种剪法共可收集到4+6=10个珠子。

要求: 在项链中选择合适的剪断位置, 使得从左右两端收集到的珠子数目之和最大,输出收集到的珠子数的最大值M。

输入格式
  由小写字母b,r,w组成的字符串。此字符串记录了一个首尾相接的项链从某处断开后,按顺时针顺序得到的珠子的直线排列。
输出格式
  收集到的珠子数的最大值 M
样例输入

wbbbwwrrbwbrrwb

样例输出

10
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.StreamTokenizer;
import java.util.HashSet;
import java.util.Set;

public class Main {
    public static void main(String[] args) throws IOException {
        StreamTokenizer st = new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in)));
        st.nextToken();
        String str = st.sval;
        int a = str.length();
        int count = 1;
        //i代表切割的位置
        for (int i = 0; i < a; i++) {
            int temp = 0, j, k;
            char[] change;
            try {
                String str1 = str.substring(i, a) + str.substring(0, i);
                change = str1.toCharArray();
            } catch (Exception e) {
                continue;
            }
            //从左向右遍历一次
            Set<Character> set1 = new HashSet<>();
            for (j = 0; j < a; j++) {
                if (change[j] != 'w') {
                    if (set1.isEmpty()) {
                        set1.add(change[j]);
                        temp++;
                    } else if (set1.contains(change[j])) {
                        temp++;
                    } else {
                        break;
                    }
                } else {
                    temp++;
                }
            }
            Set<Character> set2 = new HashSet<>();
            //从右往左遍历一次
            for (k = a - 1; k > j; k--) {
                if (change[k] != 'w') {
                    if (set2.isEmpty()) {
                        set2.add(change[k]);
                        temp++;
                    } else if (set2.contains(change[k])) {
                        temp++;
                    } else {
                        break;
                    }
                } else {
                    temp++;
                }
            }
            count = Math.max(temp, count);
        }
        System.out.print(count);
    }
}


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一般的一天

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值