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

题目描述

思路

这个和翻硬币的那个题很像,不过翻硬币只有翻或不翻,二元状态,但这个修改,可以修改成任何数,因为我们想要令修改次数最少,即某个位置上的某个字母出现的最多(看代码理解),那我们就把其余不是他的都改成最多的,这样就是修改最少了

代码

统计每个位置上出现的次数(因为修改是修改成重复的字符串,即abcebf,要想修改成2个重复的,即abcabc , 每个位置上要对应)

要读题!!如果不能整除!要输出-1!!!!!!!!!!不要看一半!

cpp 复制代码
#include<bits/stdc++.h>

using namespace std;

const int N = 1e5+10;

char s[N];
int cnt[N];
int main()
{
	int n;
	cin >> n;
	cin >> s;
	
	int len = strlen(s);  //求长度
	if(len % n != 0)
	{
		cout<<"-1"<<endl;
		return 0;
	}
	int k = len / n;//每个划分后的字符串长度
	//如何统计每个位置的字符串出现的次数?
	//代码能力
	int maxx = 0;
	int ans = 0;
	for(int i = 0; i < k; i++)
	{
		maxx = 0;
		memset(cnt, 0, sizeof cnt); //别忘了对cnt数组初始化
		for(int j = 0; j < n; j++)
		{
			cnt[s[i+k * j] - 'a']++; //统计每个位置的,有点难想,不过可以记下来
			maxx = max(maxx, cnt[s[i+k * j] - 'a']); //直接比较了,也不用再遍历一遍了
		}
		ans += n - maxx;
	}
	cout<<ans<<endl;
	return 0;
}

总结

认真读题!!

有时候不满足输出-1可以混分!!

相关推荐
STY_fish_201238 分钟前
手拆STL
java·c++·算法
小纭在努力42 分钟前
【算法设计与分析】实验——改写二分搜索算法,众数问题(算法分析:主要算法思路),有重复元素的排列问题,整数因子分解问题(算法实现:过程,分析,小结)
数据结构·python·学习·算法·算法设计与分析·实验报告·实验
芜湖xin2 小时前
【题解-洛谷】B4278 [蓝桥杯青少年组国赛 2023] 简单算术题
算法·
理智的灰太狼2 小时前
题目 3298: 蓝桥杯2024年第十五届决赛真题-兔子集结
算法·职场和发展·蓝桥杯
kingmax542120085 小时前
【洛谷P9303题解】AC- [CCC 2023 J5] CCC Word Hunt
数据结构·c++·算法·广度优先
白熊1885 小时前
【机器学习基础】机器学习入门核心算法:XGBoost 和 LightGBM
人工智能·算法·机器学习
bai_lan_ya6 小时前
数据结构-排序-排序的七种算法(2)
数据结构·算法·排序算法
全域智图7 小时前
元胞自动机(Cellular Automata, CA)
人工智能·算法·机器学习
珂朵莉MM7 小时前
2022 RoboCom 世界机器人开发者大赛-本科组(省赛)解题报告 | 珂学家
人工智能·算法·职场和发展·深度优先·图论
独家回忆3647 小时前
每日算法-250601
数据结构·算法