牛牛最近在玩炉石传说,这是一款一对一对战的卡牌游戏,牛牛打算努力冲上钻五分段,获得丰厚的天梯奖励。炉石传说的段位可以用星数来表示,具体规则为:若牛牛本场失败,则扣除一星;若牛牛本场获胜,需要看牛牛是否触发了连胜奖励,若牛牛获得了至少三连胜(即本局对局的上一局和上上局都获胜)则获得k星,否则获得一星。现在给出牛牛游玩的n场记录,请你判断牛牛最终的星数和初始星数的差。
思想:此题模拟即可。遍历字符串,遇到L就减一;遇到W判断判断前两个是否也为W,如果为连胜就加k,如果不是就加一即可。
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int t = in.nextInt();
while(t-- != 0){
int n = in.nextInt();
int k = in.nextInt();
char[] s = in.next().toCharArray();
int ret = 0;
for(int i = 0; i < s.length; i++){
if(s[i] =='L'){
ret -=1;
}else{
if(i-1 >= 0 && i-2 >= 0 && s[i-1] == 'W' && s[i-2] == 'W'){
ret += k;
}else{
ret += 1;
}
}
}
System.out.println(ret);
}
}
}