刷题刷出新高度,偷偷领先!偷偷领先!偷偷领先! 关注我们,悄悄成为最优秀的自己!

简答题

4.二进制串的评分
对于一个给定的二进制串 s(即仅由字符 0 和 1 组成的串),其评分是这样计算的:将原串切分为若干段,使得每段包含的字符是一样的,且相邻两段包含的字符是不一样的。该字符串的评分定义为各段长度的异或值(如果只有一段,评分就是这段的长度)。
异或(Exclusive OR,简称 XOR)是一种数学运算符,用于计算机中的位运算。当且仅当两个输入值不同时,异或运算输出为真(1),否则输出为假(0)。
例如,串 "10001100001" 可以切分为 5 段,即 "1"、"000"、"11"、"0000"、"1",其评分就是 1 ^ 3 ^ 2 ^ 4 ^ 1 = 5。
假设每一步我们可以交换 2 个相邻的字符,并且可以这样执行任意多步(当然也可以执行 0 步)。对每个可能的评分 x,你能得到多少个不同的串?将原串 s 通过交换操作变成评分为 x 的串,所用的最少步骤是多少次?
时间限制:1000
内存限制:65536
输入
输入在一行中给出非空的原始二进制串 s,其长度不超过 64。
输出
对每个可能的评分,在一行中输出 3 个空格分隔的整数,依次为:评分值、对 s 执行任意多步交换后能得到的不同串的个数、将 s 通过交换操作变成该评分的串所需要的最少步骤数。 按评分的升序输出。
样例输入
```
010
样例输出
1 1 0
3 2 1
```

使用微信搜索喵呜刷题,轻松应对考试!

答案:

解析:

这个问题涉及到字符串的切割、异或运算、频次统计和最少步骤数的计算。需要理解异或运算的性质和字符串切割的方式,通过遍历字符串并统计不同评分的频次来解决问题。同时,考虑到每步可以交换两个相邻字符,我们需要通过计算频次的减一来得到最少步骤数。

创作类型:
原创

本文链接:4.二进制串的评分对于一个给定的二进制串 s(即仅由字符 0 和 1 组成的串),其评分是这样计算的

版权声明:本站点所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明文章出处。

让学习像火箭一样快速,微信扫码,获取考试解析、体验刷题服务,开启你的学习加速器!

分享考题
share