1039字符消除

来源:互联网 发布:ssd优化工具 编辑:程序博客网 时间:2024/05/29 15:59

#1039字符消除

描述

小Hi最近在玩一个字符消除游戏。给定一个只包含大写字母”ABC”的字符串s,消除过程是如下进行的:

1)如果s包含长度超过1的由相同字母组成的子串,那么这些子串会被同时消除,余下的子串拼成新的字符串。例如”ABCCBCCCAA”中”CC”,”CCC”和”AA”会被同时消除,余下”AB”和”B”拼成新的字符串”ABB”。

2)上述消除会反复一轮一轮进行,直到新的字符串不包含相邻的相同字符为止。例如”ABCCBCCCAA”经过一轮消除得到”ABB”,再经过一轮消除得到”A”

游戏中的每一关小Hi都会面对一个字符串s。在消除开始前小Hi有机会在s中任意位置(第一个字符之前、最后一个字符之后以及相邻两个字符之间)插入任意一个字符(‘A’,’B’或者’C’),得到字符串t。t经过一系列消除后,小Hi的得分是消除掉的字符的总数。

请帮助小Hi计算要如何插入字符,才能获得最高得分。
输入
输入第一行是一个整数T(1<=T<=100),代表测试数据的数量。

之后T行每行一个由’A”B”C’组成的字符串s,长度不超过100。

输出
对于每一行输入的字符串,输出小Hi最高能得到的分数。

提示
第一组数据:在”ABCBCCCAA”的第2个字符后插入’C’得到”ABCCBCCCAA”,消除后得到”A”,总共消除9个字符(包括插入的’C’)。

第二组数据:”AAA”插入’A’得到”AAAA”,消除后得到”“,总共消除4个字符。

第三组数据:无论是插入字符后得到”AABC”,”ABBC”还是”ABCC”都最多消除2个字符。

样例输入
3
ABCBCCCAA
AAA
ABC
样例输出
9
4
2

代码块

import java.util.Scanner;import java.util.Stack;public class Main {    public static void main(String[] args) {        Scanner sc = new Scanner(System.in);        int n = sc.nextInt();        String[] strArr = new String[n];        sc.nextLine();        for(int i = 0; i < strArr.length; i++) {            strArr[i] = sc.nextLine();        }        for(int i = 0; i < strArr.length; i++) {            System.out.println(new Main().totalSum(strArr[i]));        }        //System.out.println(new Main().totalSum("ABC"));    }    //将字符串处理一遍后的结果    String oneStr(String a) {        String str = "";        char []arr = a.toCharArray();        Stack<Character> s = new Stack<Character>();        int i = 0;        boolean flag = true;        while(i < arr.length) {            if(flag == false) {                s.push(arr[i]);                i++;                flag = true;                continue;            }            if(s.empty()) {                s.push(arr[i]);                i++;                continue;            }            char tmp = s.pop();            if(arr[i] != tmp) {                s.push(tmp);                s.push(arr[i]);                i++;                continue;            } else {                while(++i < arr.length && arr[i] == tmp);                flag = false;            }        }        for(int j = 0; j < s.size(); j++) {            str += s.get(j);        }        return str;    }    //将字符串完全消除后的长度    int sum(String s) {        String pre = s;        String oneStr = oneStr(s);        while(pre.equals(oneStr) == false) {            pre = oneStr;            oneStr = oneStr(pre);        }        return s.length() - pre.length();    }    //添加    int totalSum(String s) {        int length = s.length();        char obj[] = {'A', 'B', 'C'};        int max = 0;        int temp = 0;        for(int j = 0; j < obj.length; j++) {            char c = obj[j];            for(int i = 0; i <= length; i++) {                StringBuilder sb = new StringBuilder(s);                sb.insert(i, c);                String str = sb.toString();                temp = sum(str);                if(max < temp) max = temp;            }        }        return max;    }}
0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 宝宝上课坐不住不听老师话怎么办 三岁宝宝特调皮打他还还手怎么办 怀孕40天不知道喝酒了怎么办 怀孕四十天的时候喝酒抽烟了怎么办 宝宝怀孕三十天左右喝酒了怎么办 两个人都喝酒了意外怀孕怎么办 不知道自己怀孕了喝了很多酒怎么办 不知道自己怀孕了喝了一次酒怎么办 我儿子11岁了有多动症怎么办 面对老师的冷暴力家长该怎么办? 面对无德的老师家长该怎么办 如果你家长屏蔽老师老师该怎么办 小孩出完水痘后身上出现疱疹怎么办 脑子里兴奋的头疼怎么办 吃什么药 一个月宝宝异常兴奋不睡觉怎么办 四个月宝宝晚上兴奋不睡觉怎么办 20个月宝宝半夜惊醒哭闹怎么办 小孩吃了氨茶碱兴奋不睡觉怎么办 孩子在学校被同学撞鼻骨折怎么办 孩子在学校无意致使同学受伤怎么办 9个月的宝宝吃坏东西腹泻怎么办 8个月发烧到38度怎么办 1岁半宝宝鼻塞发烧38度6怎么办 八个月的宝宝发热38度怎么办 八个月宝宝发热在38度怎么办 8个月孩子发烧38度怎么办 6个月孩子发烧38度多怎么办 7个月孩子发烧38度怎么办 小明上课总是东张西望你该怎么办 初中二年级贪玩游戏说不听怎么办 孩子上课经常和别的同学说话怎么办 小孩五年级了上课坐不住怎么办 孩子老是纠结小事抓不住重点怎么办 没文化不懂教不了孩孑怎么办 孩孑学习不好老师不让上课怎么办 5个月婴儿睡得少怎么办 教育案例——幼儿爱打小报告怎么办 上班的时候同事老是爱插话怎么办 孕晚期右侧卧睡觉宝宝好动怎么办 乐扣玻璃碗盖子长霉怎么办 乐扣保鲜盒密封圈有异味怎么办