AGC011D Half Reflector

传送门

题意:
有k个球被从左边放入最左边的某种设备里面,这种设备满足以下性质:
若当前状态为A,则球从进入的方向被弹出,设备状态变为B。
若当前状态为B,则球从进入的反方向被弹出,设备状态变为A。
已知n个设备的初始状态,求最后状态。

题解:
当第一个设备的状态是A时,直接弹出,第一个变成B。
否则可以打表找规律,发现每一次操作都会从右边出去,且操作后的状态正好就是左移后取反。那么就可以每次O(1)地移动一下首尾的位置和是否取反。
但是k特别大,需要优化。
可以找规律发现最后k>2n时会出现以下情况:
BABABA->BABABA
ABABA->BBABA->ABABA

代码:

#include<cstdio>
#define maxn 200005
int n,k,l,r;
bool rev;
char s[maxn];
int main()
{
	scanf("%d%d%s",&n,&k,s);
	for(int i=0;i<n;i++) s[i]-=65;
	if(k>n*2+1) k=k%2?(n*2+1):(n*2+2);
	r=n-1;
	for(int i=1;i<=k;i++) 
	{
		if(!(s[l]^rev)) s[l]^=1;
		else l=(l+1)%n,r=(r+1)%n,rev^=1;
	}
	for(;;l=(l+1)%n)
	{
		printf("%c",65+(s[l]^rev));
		if(l==r) break;
	}
}
可升级, Reflector是一款比较强大的反编译工具,相信很多朋友都用过它,但reflector本身有很多局限性,比如只能一个一个的查看方法等,但幸好reflector支持插件功能目前网上有很多reflector的插件,本人找取了两个应用范围很广,并且广受好评的插件:Reflector.FileDisassembler和Reflector.FileGenerator和Reflector进行了整合,放在了一个压缩包中,大家可以直接解压缩后就开始使用,其中FileGenerator在网上没有现成dll,本人编译后将其取出,放在了压缩包中,一直在苦苦找寻的朋友这次可以拿来直接用了:) 本压缩包中Reflector.exe已经升级为最新的5.0版本,具体的使用方法不多说了,只简单介绍一下本压缩包的使用步骤: 先下载本压缩包并解压缩,运行其中的Reflector.exe(主程序),初次运行会弹出错误提示对话框,因为引用的两个插件DLL是按照我本地实际情况配置的,所以你还需要根据你的实际情况来从新配置一下,方法很简单,我们拿引用FileGenerator.dll来做一个范例, 首先介绍一下Filegenerator,FileGenerator插件的作用是:根据dll文件,把里面的源文件导出成文件,导出来的文件除了没有注释,变量名也变了,其它的可谓是没有差别。对于一些比较好的控件,如果不是开源的,完全可以导出成文件,然后自己加上注释,少许修改,很好的利用起来。(不开源的dll,用起来也不放心啊) 具体的初始化设置方法:点击View->Add-Ins...,弹出一个窗口,然后点击Add->选择文件夹里面的:"FileGenerator.dll",点击close. 然后回到Reflector窗口,Tool->Generator File(s)... 右边就出现了插件的窗口,选中左边的dll文件,点击右边的导出文件,源代码就全部导出来了! 另一个插件Reflector.FileDisassembler.dll设置方法也和这个一样,另外再提供一些Reflector的相关插件下载,
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值