P8739 [蓝桥杯 2020 国 C] 重复字符串

[蓝桥杯 2020 国 C] 重复字符串

题目描述

如果一个字符串 S S S 恰好可以由某个字符串重复 K K K 次得到,我们就称 S S S 是 K K K 次重复字符串。例如 abcabcabc 可以看作是 abc 重复 3 3 3 次得到,所以 abcabcabc 是 3 3 3 次重复字符串。

同理 aaaaaa 既是 2 2 2 次重复字符串、又是 3 3 3 次重复字符串和 6 6 6 次重复字符串。

现在给定一个字符串 S S S,请你计算最少要修改其中几个字符,可以使 S S S 变为一个 K K K 次字符串?

输入格式

输入第一行包含一个整数 K K K。

第二行包含一个只含小写字母的字符串 S S S。

输出格式

输出一个整数代表答案。如果 S S S 无法修改成 K K K 次重复字符串,输出 − 1 −1 −1。

样例 #1

样例输入 #1

2
aabbaa

样例输出 #1

2

提示

其中, 1 ≤ K ≤ 1 0 5 1 \le K \le 10^5 1≤K≤105, 1 ≤ ∣ S ∣ ≤ 1 0 5 1 \le |S| \le 10^5 1≤∣S∣≤105。其中 ∣ S ∣ ∣S∣ ∣S∣ 表示 S S S 的 长度。

蓝桥杯 2020 年国赛 C 组 G 题。

cpp 复制代码
#include<iostream>
#include<cstring>
#include<string>
#include<map>
using namespace std;
int n,mmax;
string s;
int sum;
int main()
{
	
	cin>>n>>s;
	if(s.size()%n!=0){
		cout<<-1;//不能被整除直接排除
		return 0;
	}
	int t=s.size()/n;//可以分为几组
	for(int i=0;i<t;i++)//循环组数
	{
		
		map<char,int>mm;//记录每一组的各个位置上的字母出现个数
		int res=0;//答案
		for(int j=i;j<s.size();j+=t)
		{//这里是+t,一组一组来看
			mm[s[j]]++;		
		}
		for(int i=0;i<+26;i++)
		{
			
			res=max(res,mm[i+'a']);	
		}
		sum+=n-res;//把不一样的的其他数删咯的和
	}
	cout<<sum;
	return 0;	
}
相关推荐
不穿格子衬衫5 小时前
常用排序算法(下)
c语言·开发语言·数据结构·算法·排序算法·八大排序
aqua35357423585 小时前
蓝桥杯-财务管理
java·c语言·数据结构·算法
CV金科5 小时前
蓝桥杯—STM32G431RBT6(IIC通信--EEPROM(AT24C02)存储器进行通信)
stm32·单片机·嵌入式硬件·算法·蓝桥杯
Word码6 小时前
数据结构:栈和队列
c语言·开发语言·数据结构·经验分享·笔记·算法
五花肉村长6 小时前
数据结构-队列
c语言·开发语言·数据结构·算法·visualstudio·编辑器
qinzechen7 小时前
分享几个做题网站------学习网------工具网;
java·c语言·c++·python·c#
希望有朝一日能如愿以偿7 小时前
力扣题解(飞机座位分配概率)
算法·leetcode·职场和发展
yttandb8 小时前
重生到现代之从零开始的C语言生活》—— 内存的存储
c语言·开发语言·生活
结衣结衣.9 小时前
python中的函数介绍
java·c语言·开发语言·前端·笔记·python·学习
五味香9 小时前
C++学习,信号处理
android·c语言·开发语言·c++·学习·算法·信号处理