Codeforces405 B. Domino Effect

本文介绍了Codeforces 405 B题目的解题思路,探讨了骨牌最终直立的条件,包括从左到右扫描判断直立骨牌的方法①,以及将连续L/R等效简化问题的方法②。
摘要由CSDN通过智能技术生成

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

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值