当前位置: 首页 > article >正文

蓝桥杯2020年国赛C/C++C组第7题 重复字符串(思维与贪心)

 解题思路:首先明确,若能将S变为一个K次字符串,那么它的长度应该是K的倍数,如果不是,那么就无法将S变为一个K次字符串,直接按题目要求输出-1即可,如果是,就开始遍历(S/K)长度的字符串它的每一个字符,而既然是一个K次字符串,那么这个(S/K)长度的字符串它的每一个字符应该出现K次,而这个字符串每一个字符的修改都是互不影响的,即我们可以通过贪心策略,在每一个字符的K次遍历中,把字符修改成出现最多的那一个字符,那么修改次数即为每一个字符中的最少情况,我们将(S/K)字符串中的所有字符的修改次数进行统计,完成输出即可

#include<stdio.h>
#include<string.h> 
int max(int a,int b)
{
 return a>=b?a:b;//定义一个返回两者之间较大值的函数
}
int main()
{
 const int N=1e5+10;
  char s[N];//定义一个足以满足题目字符串输入长度的字符数组
  int k;
  int count[26]={0};//统计a到z的出现次数
  int sum=0;
  int i,j; 
  scanf("%d",&k);
  getchar();//吞掉换行符,防止对后续输入造成影响
  gets(s);
  if(strlen(s)%k!=0) printf("-1");//如果字符串S长度不为K的倍数(余数不为0) 输出-1
  else
  {
   int n=strlen(s)/k;//计算拆分成K次后的小字符串的长度
   for(i=0;i<n;i++)//遍历小字符串的每一个字符
   {
    for(j=0;j<26;j++) count[j]=0;//每一次遍历时,将count数组初始化为0,代表a到z还未曾出现
    int ma=0;//统计出现最多的次数
    for(j=0;j<k;j++)//把K次出现过的字符全部找出来
    {
     char x=s[i+j*n];//把当前遍历的这个字符存储进一个字符变量
     count[x-'a']++;//这个字符每出现一次,就统计一次
     ma=max(ma,count[x-'a']);//更新出现最多的字符它的出现次数
    }
    sum+=k-ma;//将不是出现的最多的字符都改为出现最多的字符,就完成了每一次的修改最少情况
   }
   printf("%d",sum);//遍历完小字符串的所有字符,那么修改次数之和便是整个字符串需要的最小修改次数
  }                 //完成输出
  return 0;
}

 

 


http://www.kler.cn/a/506267.html

相关文章:

  • 使用jupyter notebook没有正常打开浏览器的几种情况解决
  • qml LevelAdjust详解
  • 机器学习实战33-LSTM+随机森林模型在股票价格走势预测与买卖点分类中的应用
  • Mysql--实战篇--数据库设计(范式和反范式,数据表设计原则)
  • 【深度学习实战】kaggle 自动驾驶的假场景分类
  • 业务幂等性技术架构体系之消息幂等深入剖析
  • 软件授权管理中的软件激活向导示例
  • 图论1-问题 C: 算法7-6:图的遍历——广度优先搜索
  • 高级Python Web开发:FastAPI的前后端集成与API性能优化
  • 计算机网络 (46)简单网络管理协议SNMP
  • AV1视频编解码简介、码流结构(OBU)
  • 【Idea启动项目报错NegativeArraySizeException】
  • ASP.NET Core WebApi接口IP限流实践技术指南
  • 基于springboot+mybatis-plus的线上订餐系统项目
  • ubuntu开机自启,其他方式
  • 二、学习SpringMVC
  • 微软徽标认证WHQL
  • thinkphp6 + redis实现大数据导出excel超时或内存溢出问题解决方案
  • Nvidia Blackwell架构深度剖析:深入了解RTX 50系列GPU的升级
  • leetcode118.杨辉三角
  • C++实现设计模式---外观模式 (Facade)
  • RK3399开发板Linux实时性改造
  • STM32+W5500+以太网应用开发+003_TCP服务器添加OLED(u8g2)显示状态
  • stm32步进电机曲线控制程序
  • 【2025 Rust学习 --- 18 IO操作和网络】
  • 基于unity的多人家装应用的设计与实现