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;	
}
相关推荐
memcpy010 分钟前
LeetCode 1456. 定长子串中元音的最大数目【定长滑窗模板题】中等
算法·leetcode·职场和发展
玛丽莲茼蒿29 分钟前
LeetCode hot100【相交链表】【简单】
算法·leetcode·职场和发展
炸膛坦客2 小时前
单片机/C/C++八股:(十六)C 中 malloc/free 和 C++ 中 new/delete 有什么区别?
c语言·开发语言·c++
Navigator_Z2 小时前
LeetCode //C - 990. Satisfiability of Equality Equations
c语言·算法·leetcode
Book思议-3 小时前
【数据结构实战】双向链表:在指定位置插入数据
c语言·数据结构·算法·链表
酉鬼女又兒3 小时前
入门前端CSS 媒体查询全解析:从入门到精通,打造完美响应式布局(可用于备赛蓝桥杯Web应用开发)
前端·css·职场和发展·蓝桥杯·前端框架·html5·媒体
C羊驼3 小时前
C/C++数据结构与算法:穷举法
c语言·c++·笔记·学习·算法
小则又沐风a4 小时前
[蓝桥杯 2014 省 AB] 蚂蚁感冒
算法·职场和发展·蓝桥杯
程序员敲代码吗4 小时前
USB-C接口深度测试:从Vconn到电压的全方位分析
c语言·开发语言
Hello eveybody4 小时前
C语言的发明者介绍
c语言