http://codeforces.com/problemset/problem/405/B

题意:给出n个骨牌倒的方向(左,右,不动),求最后保持直立的骨牌个数。

思路:我是花了很大的功夫才搞好了这道题

方法①:从左到右扫一遍,一个位置i最后直立,只有以下几种情况:(先找出i向左/右第一个原始不直立的点,记为l,r)

l空&r是R,r空&l是L,rl均空,l是L&r是R,l是R&r是L&i距离l和r相同。

方法②:连续的L或R可以等效成一个L或R,因此把题目所给等效成L和R交替出现,就好做了。

方法1代码:

#include <bits/stdc++.h>
using namespace std;
#define maxn 4000

int n,ans;
char a[maxn];



int main()
{
	//freopen("input.in","r",stdin);
	cin>>n;
	scanf("%s",a+1);
	for(int i=1;i<=n;i++)if(a[i]=='.')
	{
		int l,r;
		for(l=i-1;l>=1;l--)
		{
			if(a[l]!='.')break;
		}
		for(r=i+1;r<=n;r++)
		{
			if(a[r]!='.')break;
		}
		if(!l&&r==n+1||!l&&a[r]=='R'||r==n+1&&a[l]=='L')ans++;
		else if(l&&r<=n&&a[l]=='L'&&a[r]=='R')ans++;
		else if(l&&r<=n&&a[l]=='R'&&a[r]=='L'&&i-l==r-i)ans++;
	}
	cout<<ans;
	return 0;
}