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;
}