Good String

Posted karshey

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Good String相关的知识,希望对你有一定的参考价值。

You have a string s of length n consisting of only characters > and <. You may do some operations with this string, for each operation you have to choose some character that still remains in the string. If you choose a character >, the character that comes right after it is deleted (if the character you chose was the last one, nothing happens). If you choose a character <, the character that comes right before it is deleted (if the character you chose was the first one, nothing happens).

For example, if we choose character > in string > > < >, the string will become to > > >. And if we choose character < in string > <, the string will become to <.

The string is good if there is a sequence of operations such that after performing it only one character will remain in the string. For example, the strings >, > > are good.

Before applying the operations, you may remove any number of characters from the given string (possibly none, possibly up to n−1, but not the whole string). You need to calculate the minimum number of characters to be deleted from string s so that it becomes good.

Input
The first line contains one integer t (1≤t≤100) – the number of test cases. Each test case is represented by two lines.

The first line of i-th test case contains one integer n (1≤n≤100) – the length of string s.

The second line of i-th test case contains string s, consisting of only characters > and <.

Output
For each test case print one line.

For i-th test case print the minimum number of characters to be deleted from string s so that it becomes good.

Example

Input
3
2
<>
3
><<
1
>
Output
1
0
0

Note
In the first test case we can delete any character in string <>.

In the second test case we don’t need to delete any characters. The string > < < is good, because we can perform the following sequence of operations: > < < → < < → <.

>后的删去,<前的删去。因此,找到第一个>或最后一个<,输出它们的min。

#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
int main()
{
	//>后的删去,<前的删去 
	int n;
	cin>>n;
	while(n--)
	{
		int m,d=0,x=0;
		cin>>m;
		vector<char>v;
		vector<char>::iterator iter;
		char ch;
		for(int i=0;i<m;i++)
		{		
			cin>>ch;
			v.push_back(ch);
			if(ch=='<') x++;
			else d++;			
		}
		
		if(d==0||x==0) cout<<0<<endl;
		else
		{
			//找第一个>
			int d1=0;
			for(int i=0;i<m;i++)
			{
				if(v[i]=='>')
				{
					d1=i;
					break;
				}
			}
			
			//找最后一个< 
			int x1=0;
			for(int i=0;i<m;i++)
			{
				if(v[i]=='<')
				{
					x1=i;					
				}
			}
			
			x1=m-1-x1;
			cout<<min(d1,x1)<<endl;
		}
	}
	return 0;
}

以上是关于Good String的主要内容,如果未能解决你的问题,请参考以下文章

C Good String Codeforces Round #560 (Div. 3)

@AspectJ support (good)

题解 CF1385D a-Good String

Java InputStreamStringFile相互转化 --- good

CSP核心代码片段记录

如何将代码片段存储在 mongodb 中?