B. 比較文字列

トピック:

例:

入力
4
4
<<>>
4
>><<
5
>>>>>
7
<><><><

出力
3
3
6
2

アイデア:

        質問の意味によると、条件は

使用する数値をできる限り少なくする必要があるため、これは欲張りな質問なので、次のことがわかります。

同じシンボルに遭遇した場合は、新しい数値のみを使用する必要があります。つまり、使用された数値の数が累積され、累積 ++cnt され、その後、ans は可能な限り使用する数値の数を取得します。 ans = max(ans,cnt )

異なるシンボルに遭遇した場合、以前に使用した数値を使用して数値の累積を回避できます。つまり、最初の数値 cnt = 1 に戻り、数値の累積をリセットします。

コードについては以下で詳しく説明します。

#include <iostream>
#include <cstring>
#include <algorithm>
#include <queue>
#include <unordered_map>
#define endl '\n'
#define int long long
#define YES puts("YES")
#define NO puts("NO")
#define umap unordered_map
#define All(x) (x).begin(),(x).end()
#pragma GCC optimize(3,"Ofast","inline")
#define ___G std::ios::sync_with_stdio(false),cin.tie(0), cout.tie(0)
using namespace std;
const int N = 2e6 + 10;

inline void solve()
{
	string s;
	int n;
	
	cin >> n >> s;
	
	int cnt = 1;	// 肯定有一个数字做开头
	int ans = cnt;	// 存储我们尽可能使用的数字数量
	
	for(int i = 1;i < n;++i)
	{
		if(s[i] == s[i - 1])
		{
			// 如果遇到符号相同
			// 肯定需要新的数字
			++cnt;
		}else cnt = 1;	// 否则我们使用最初的数字,达到重置重新累计的效果,尽可能用重复的数字
		ans = max(ans,cnt);
	}
	
	// 最后的 ++ans 是累计我们最后会用到的数字
	++ans;
	
	cout << ans << endl;
}


signed main()
{
//	freopen("a.txt", "r", stdin);
	___G;
	int _t = 1;
	cin >> _t;
	while (_t--)
	{
		solve();
	}

	return 0;
}

最後のコミット:

おすすめ

転載: blog.csdn.net/hacker_51/article/details/133465810