Mathematicians and brackets

这道题的题意我当时真是没怎么读懂,尤其是这一句“A string a is a cyclic shift of a string b if a and b have the same lengths and a consists of some (possibly empty) suffix from b followed by a prefix from b.”。意思是:字符串a是字符串b 的循环移动,当且仅当a包含b的后缀(可能为空),后面跟着b的前缀。例如)((),这就是串b,有四种串a符合上述条件的移动,(())、 ())(、 ))((、 )((),其中第一种可以把串变成普通的串,因此答案为1。

这道题的处理思路我真是想不到,即使他们给我讲了,我还是不能完全理解,这种思维很难在做题中想到。首先设一个参数t,t=0表示左右括号数目相同,在遍历串时,若为'(',t++,若为')',t--,vMin是最小的t,表示的意思我也表述不出来-_-。然后再次从头开始遍历串,若为'(',则vMin--,若为')',则vMin++,当vMin>=0,ans++,即是一种所要求的循环移动,最后输出ans即可。

其实我对这道题的理解还是很肤浅,有些处理方法还是不懂,还需要时间来消化……

程序代码(仿照同学的神码):

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值