来源:牛客网
题目描述
牛牛现在有一个长度n的字符串(仅包含小写字母),他现在把这个字符串,每隔k个就分出来一个子串,比如[1,k]为第一个子串,[k+1,2k]为第二个、[2k+1,3k]为第三个…(保证n%k=0)
牛牛想要把这些子串都变成一样的。他可以选择任意一个子串的任意一个字符进行更改,但是他太懒了,他想让你帮他算算最少要进行多少次操作。
输入描述:
第一行输入n(1≤n≤10^6)和k(1≤k≤n 数据保证n%k=0),第二行输入该字符串。
输出描述:
输出需要的最少操作次数
题解:
每个子串长度都是一样的,求出每个子串的第一个字符的次数,最多不用改变,其他的全部变为最多那个字符就行了,如果每个字符一样的次数一样多,则随便改成哪个个字符一样就可以
同理,对所有子串的第 2 个至第 k 个字符,使用同样的操作。然后把这些操作次数相加起来就是最终答案。
#include<iostream