现在的位置: 首页 > 综合 > 正文

A. Down the Hatch!

2014年11月01日 ⁄ 综合 ⁄ 共 2388字 ⁄ 字号 评论关闭

time limit per test

2 seconds

memory limit per test

256 megabytes

input

standard input

output

standard output

Everybody knows that the Berland citizens are keen on health, especially students. Berland students are so tough that all they drink is orange juice!

Yesterday one student, Vasya and his mates made some barbecue and they drank this healthy drink only. After they ran out of the first barrel of juice, they decided to play a simple game. All n people
who came to the barbecue sat in a circle (thus each person received a unique index bi from
0 to n - 1). The person number 0 started the game (this time it was Vasya). All turns in the game were numbered by integers starting from
1. If the j-th turn was made by the person with index bi,
then this person acted like that:

  1. he pointed at the person with index (bi + 1) mod n either
    with an elbow or with a nod (x mod y is the remainder after dividing x by y);
  2. if j ≥ 4 and the players who had turns number j - 1j - 2j - 3,
    made during their turns the same moves as player bi on
    the current turn, then he had drunk a glass of juice;
  3. the turn went to person number (bi + 1) mod n.

The person who was pointed on the last turn did not make any actions.

The problem was, Vasya's drunk too much juice and can't remember the goal of the game. However, Vasya's got the recorded sequence of all the participants' actions (including himself). Now Vasya wants to find out the maximum amount of juice he could drink if
he played optimally well (the other players' actions do not change). Help him.

You can assume that in any scenario, there is enough juice for everybody.

Input

The first line contains a single integer n (4 ≤ n ≤ 2000)
— the number of participants in the game. The second line describes the actual game: the i-th character of this line equals 'a',
if the participant who moved i-th pointed at the next person with his elbow, and 'b',
if the participant pointed with a nod. The game continued for at least 1 and at most 2000 turns.

Output

Print a single integer — the number of glasses of juice Vasya could have drunk if he had played optimally well.

Sample test(s)
input
4
abbba
output
1
input
4
abbab
output
0
Note

In both samples Vasya has got two turns — 1 and 5. In the first sample, Vasya could have drunk a glass of juice during the fifth turn if he had pointed at the next person with a nod. In this case, the sequence of moves would look like "abbbb". In the second
sample Vasya wouldn't drink a single glass of juice as the moves performed during turns 3 and 4 are different.

解题说明:题目虽然很长,但是分析一下发现其实不难,给你n个人,开始报a或者b,第一个人开始然后轮流报数,如果你前面三个人连续报的是一样的字母就喝一杯酒。问你第一个人喝几杯酒?

#include <cstdio>
#include<iostream>
using namespace std;

char s[2005];

int main() 
{
	int n,i;
	int cnt = 0;	
	scanf("%d%s", &n, s);
	for( i = n; s[i]; i+=n) 
	{
		if(s[i-1] == s[i-2] && s[i-2] == s[i-3])
		{
			cnt++;
		}
	}
	printf("%d\n", cnt);
}

【上篇】
【下篇】

抱歉!评论已关闭.