热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

蓝桥杯算法训练字串统计ByAssassin字符串操作+离散化

问题描述给定一个长度为n的字符串S,还有一个数字L,统计长度大于等于L的出现次数最多的子串(不同的出现可以相交),如果有多个,输出最长的,如果仍然有多个,输出第一次出现最早的。输入格式第
问题描述
  给定一个长度为n的字符串S,还有一个数字L,统计长度大于等于L的出现次数最多的子串(不同的出现可以相交),如果有多个,输出最长的,如果仍然有多个,输出第一次出现最早的。
输入格式
  第一行一个数字L。
  第二行是字符串S。
  L大于0,且不超过S的长度。
输出格式
  一行,题目要求的字符串。

  输入样例1:
  4
  bbaabbaaaaa

  输出样例1:
  bbaa

  输入样例2:
  2
  bbaabbaaaaa

  输出样例2:
  aa
数据规模和约定
  n<=60
  S中所有字符都是小写英文字母。
提示
  枚举所有可能的子串,统计出现次数,找出符合条件的那个

其实这道题是一个简单的字符串操作,只不过在处理这个问题的时候用到了一下小技巧,比如string字符串操作,map迭代器的使用,简单的离散化思想,和自定义的sort函数,对于新手还是值得学习一下的

首先我们明确数据范围就是n<=60,那么其实明显用字符串暴力记录就可以了,但是这里买你还有一定的规则,就是如果有多个,输出最长的,如果仍然有多个,输出第一次出现最早的

那么我是这么处理的,我们在记录string串用map 《string , int》,因为N<=60那么出现的最多次数不过是L=1,n=60吧!那么出现的次数最多60次吧,那么我们在处理int记录次数的时候,加上起点位置*一个大数 ,这个大数一定比60大,那么我们就可以记录该串起点的位置了,而且每次取个数的时候只需要模一下那个大数就能得到次数! 然后用map迭代器找到出现最多的次数,用结构体记录出现次数最多的串,然后我们用一个cmp自定义函数排序,具体函数如下:

int cmp(node a,node b){
if(a.s.size()>b.s.size()) return 1; //先比大小
else if(a.s.size()==b.s.size()){ //大小相同则比较 起点位置,即出现早晚,因为乘上一个大数,一定是越小越早出现!
if(a.timesreturn 1;
}
return 0;
}

下面是我的丑代码,具体见注释~

#include
using namespace std;
map<string,int>mp;
typedef struct node{
string s;
int times;
}node;
node ans[100001];
int cmp(node a,node b){
if(a.s.size()>b.s.size()) return 1; //先比大小
else if(a.s.size()==b.s.size()){ //大小相同则比较 起点位置,即出现早晚,因为乘上一个大数,一定是越小越早出现!
if(a.timesreturn 1;
}
return 0;
}

int main(){
int l;
string target,temp;
cin>>l>>target;
for(int i=0;i<=target.size()-l;i++){
for(int j=l;j<=target.size()-i;j++){
temp.assign(target,i,j);
if(mp[temp]==0){ //如果第一次出现初始化一个×大数的基底 ,离散化
mp[temp]=100000*i+1;
}
else{
mp[temp]++;
}
}
}
int maxnumber=0;
map<string,int>::iterator it; //map迭代器
for(it=mp.begin();it!=mp.end();it++){ //求出来出现最多的次数
maxnumber=max(maxnumber,(it->second)%100000); //记得取模
}

int pos=0;
for(it=mp.begin();it!=mp.end();it++){ //将出现的次数最多的串信息记录下来
if(it->second%100000==maxnumber){
ans[pos].s.assign(it->first);
ans[pos++].times=it->second;
}
}
sort(ans,ans+pos,cmp); //排序
cout<0].s< return 0;
}

推荐阅读
  • 主调|大侠_重温C++ ... [详细]
  • 本题要求在一组数中反复取出两个数相加,并将结果放回数组中,最终求出最小的总加法代价。这是一个经典的哈夫曼编码问题,利用贪心算法可以有效地解决。 ... [详细]
  • 本文将详细探讨 Java 中提供的不可变集合(如 `Collections.unmodifiableXXX`)和同步集合(如 `Collections.synchronizedXXX`)的实现原理及使用方法,帮助开发者更好地理解和应用这些工具。 ... [详细]
  • 本文探讨了符号三角形问题,该问题涉及由相同数量的“+”和“-”符号组成的三角形。通过递归回溯法,可以有效地搜索并计算符合条件的符号三角形的数量。 ... [详细]
  • 本文探讨了在 SQL Server 中使用 JDBC 插入数据时遇到的问题。通过详细分析代码和数据库配置,提供了解决方案并解释了潜在的原因。 ... [详细]
  • 深入解析Java多线程与并发库的应用:空中网实习生面试题详解
    本文详细探讨了Java多线程与并发库的高级应用,结合空中网在挑选实习生时的面试题目,深入分析了相关技术要点和实现细节。文章通过具体的代码示例展示了如何使用Semaphore和SynchronousQueue来管理线程同步和任务调度。 ... [详细]
  • 深入理解Java多线程并发处理:基础与实践
    本文探讨了Java中的多线程并发处理机制,从基本概念到实际应用,帮助读者全面理解并掌握多线程编程技巧。通过实例解析和理论阐述,确保初学者也能轻松入门。 ... [详细]
  • ListView简单使用
    先上效果:主要实现了Listview的绑定和点击事件。项目资源结构如下:先创建一个动物类,用来装载数据:Animal类如下:packagecom.example.simplelis ... [详细]
  • 本文详细介绍了Java中实现异步调用的多种方式,包括线程创建、Future接口、CompletableFuture类以及Spring框架的@Async注解。通过代码示例和深入解析,帮助读者理解并掌握这些技术。 ... [详细]
  • CentOS 6.8 上安装 Oracle 10.2.0.1 的常见问题及解决方案
    本文记录了在 CentOS 6.8 系统上安装 Oracle 10.2.0.1 数据库时遇到的问题及解决方法,包括依赖库缺失、操作系统版本不兼容、用户权限不足等问题。 ... [详细]
  • 本文详细探讨了Java中的ClassLoader类加载器的工作原理,包括其如何将class文件加载至JVM中,以及JVM启动时的动态加载策略。文章还介绍了JVM内置的三种类加载器及其工作方式,并解释了类加载器的继承关系和双亲委托机制。 ... [详细]
  • 优化SQL Server批量数据插入存储过程的实现
    本文介绍了一种改进的SQL Server存储过程,用于生成批量插入语句。该方法不仅提高了性能,还支持单行和多行模式,适用于SQL Server 2005及以上版本。 ... [详细]
  • 访问一个网页的全过程
    准备:DHCPUDPIP和以太网启动主机,用一根以太网电缆连接到学校的以太网交换机,交换机又与学校的路由器相连.学校的这台路由器与一个ISP链接,此ISP(Intern ... [详细]
  • 本文介绍了如何通过Java代码计算一个整数的位数,并展示了多个基础编程示例,包括求和、平均分计算、条件判断等。 ... [详细]
  • 本文详细介绍了一种高效的算法——线性筛法,用于快速筛选出一定范围内的所有素数。通过该方法,可以显著提高求解素数问题的效率。 ... [详细]
author-avatar
无为南子_274
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有