Remove Two Letters

一、题目

Remove Two Letters

题目描述

Dmitry has a string $ s $ , consisting of lowercase Latin letters.

Dmitry decided to remove two consecutive characters from the string $ s $ and you are wondering how many different strings can be obtained after such an operation.

For example, Dmitry has a string “aaabcc”. You can get the following different strings: “abcc”(by deleting the first two or second and third characters), “aacc”(by deleting the third and fourth characters),“aaac”(by deleting the fourth and the fifth character) and “aaab” (by deleting the last two).

输入格式

The first line of input data contains a single integer $ t $ ( $ 1 \le t \le 10^4 $ ) — number of test cases.

The descriptions of the test cases follow.

The first line of the description of each test case contains an integer $ n $ ( $ 3 \le n \le 2 \cdot 10^5 $ ).

The second line of the description of each test case contains a string $ s $ of length $ n $ consisting of lowercase Latin letters.

It is guaranteed that the sum of $ n $ for all test cases does not exceed $ 2 \cdot 10^5 $ .

输出格式

For each test case print one integer — the number of distinct strings that can be obtained by removing two consecutive letters.

样例 #1

样例输入 #1

7
6
aaabcc
10
aaaaaaaaaa
6
abcdef
7
abacaba
6
cccfff
4
abba
5
ababa

样例输出 #1

4
1
5
3
3
3
1

提示

The first example is explained in the statement.

In the third example, the following strings are obtained: “cdef”, “adef”, “abef”, “abcf”, “abcd”.

In the seventh example, any deletion will result in the string “aba”.

二、分析

找规律即可
假如s[i]==s[i+2],那么这里删除的两种情况得到的结果一样
如aba 删除前两个ab得到a,删除后两个ba得到a。

#include
using namespace std;
int main()
{
    int T;
    cin>>T;
    while(T--)
    {
        int n;string s;
        cin>>n>>s;
        int ans=n-1;
        for(int i=0;i<s.size()-2;i++)
        {
            if(s[i]==s[i+2]) ans--;
        }
        cout<<ans<<endl;
    }
}

你可能感兴趣的:(算法)