【LeetCode中等】1419.数青蛙

news2024/9/25 21:30:48

给你一个字符串 croakOfFrogs,它表示不同青蛙发出的蛙鸣声(字符串 “croak” )的组合。由于同一时间可以有多只青蛙呱呱作响,所以 croakOfFrogs 中会混合多个 “croak” 。

请你返回模拟字符串中所有蛙鸣所需不同青蛙的最少数目。

要想发出蛙鸣 “croak”,青蛙必须 依序 输出 ‘c’, ’r’, ’o’, ’a’, ’k’ 这 5 个字母。如果没有输出全部五个字母,那么它就不会发出声音。如果字符串 croakOfFrogs 不是由若干有效的 “croak” 字符混合而成,请返回 -1 。

示例 1:

输入:croakOfFrogs = “croakcroak”
输出:1
解释:一只青蛙 “呱呱” 两次
示例 2:

输入:croakOfFrogs = “crcoakroak”
输出:2
解释:最少需要两只青蛙,“呱呱” 声用黑体标注
第一只青蛙 “crcoakroak”
第二只青蛙 “crcoakroak”
示例 3:

输入:croakOfFrogs = “croakcrook”
输出:-1
解释:给出的字符串不是 “croak” 的有效组合。

提示:

1 <= croakOfFrogs.length <= 105
字符串中的字符只有 ‘c’, ‘r’, ‘o’, ‘a’ 或者 ‘k’

这道题本身不带多少的算法,个人感觉主要还是读题与模拟的考察,从题干可以知道,青蛙一次都会用croak这五个字母来叫,也就是说青蛙叫这个事不是原子的,一只青蛙叫的过程实际要进行五个音节,这个过程是可以被打断的,需要考虑字符串的连续性。其次,题干只提到了叫完五个字母才算叫完,这句话隐藏的含义是说,叫声一定是进行完的,也就是输入的字符串的长度一定是5的倍数。题目问的是至少要几只青蛙才能完成给出的叫声,一开始错误思路想成了统计所有的croak的数量,但一只青蛙可以叫完了之后继续叫,所以这道题实际上要求的,是同一时刻最多有多少只青蛙发出了c但是还没有叫完,或者说有多少只青蛙在保持叫的这个状态。

所以这道题思路就是遍历字符串,用一个数组记录每只青蛙叫的情况,如果青蛙叫到了c被别的青蛙插队了,就先进行保存,之后叫到r的时候,再接上。一只青蛙只要叫出来了c就算开始了叫,所以只要出现了c,我们就需要进行统计量的加一,相应地,如果有一只青蛙叫到了k完成了叫,统计量就可以减一,最后取统计量的最大值作为结果即可。

#include<bits/stdc++.h>
using namespace std;
int minNumberOfFrogs(string croakOfFrogs){
	if(croakOfFrogs.size()%5!=0)
		return -1;
	int m[5] = {0};
    map<char, int> mp = {{'c', 0}, {'r', 1}, {'o', 2}, {'a', 3}, {'k', 4}};
	int ans = 0;
	int cnt = 0;
	for(int i=0; i<croakOfFrogs.size(); i++){
        int t = mp[croakOfFrogs[i]];

		if(t == 0){
			m[t]++;
			cnt++;
			if(cnt>ans)
				ans = cnt;
		}	
		else{
			if(m[t-1]==0)
				return -1;
			else{
				m[t-1]--;
				if(t==4)
					cnt--;
				else
					m[t]++;
			}
			
		}
		
	}
	if(ans>0)
		return -1;
	else
		return ans;
}
int main()
{
	string s = "crocakcroraoakk";
	cout<<minNumberOfFrogs(s)<<endl;
	return 0;
 } 

在这里插入图片描述
上述代码提交之后时间和空间上都还有很大的优化空间。从时间复杂度上来看,字符串必须要遍历一遍,这是必不可少的时间,在此基础上,进行字母和数字下标的转换(map)以及处理过程是主要的时间开销,要想时间上做改进,可以把map优化掉,直接换switch-case,不仅省时间而且还能抠搜一点开辟map的空间。

int minNumberOfFrogs(string croakOfFrogs){
	if(croakOfFrogs.size()%5!=0)
		return -1;
	int m[5] = {0};
    map<char, int> mp = {{'c', 0}, {'r', 1}, {'o', 2}, {'a', 3}, {'k', 4}};
	int ans = 0;
	int cnt = 0;
	for(int i=0; i<croakOfFrogs.size(); i++){
        int t = mp[croakOfFrogs[i]];

		if(t == 0){
			m[t]++;
			cnt++;
			if(cnt>ans)
				ans = cnt;
		}	
		else{
			if(m[t-1]==0)
				return -1;
				m[t-1]--;
				if(t==4)
					cnt--;
				else
					m[t]++;		
		}
	}
	if(cnt>0)
		return -1;
	else
		return ans;
}

在这里插入图片描述
此外,查看题解前几名才发现,叫声如果合法,字符串的第一个字母必须是c,字符串的最后一个字母必须是k,利用这个条件可以减少很多的时间。

int minNumberOfFrogs(string croakOfFrogs){
	if(croakOfFrogs.size()%5!=0)
		return -1;
	if (croakOfFrogs[0]!='c'||croakOfFrogs[croakOfFrogs.length() - 1]!='k') 
		return -1;

	int m[5] = {0};
	int ans = 0;
	int cnt = 0;
	for(int i=0; i<croakOfFrogs.size(); i++){
		int id;
		switch (croakOfFrogs[i]){
			case 'c':
				id = 0;
				break;
			case 'r':
				id = 1;
				break;
			case 'o':
				id = 2;
				break;
			case 'a':
				id = 3;
				break;
			case 'k':
				id = 4;
				break;
		} 
		
		if(id == 0){
			m[id]++;
			cnt++;
			if(cnt>ans)
				ans = cnt;
		}	
		else{
			if(m[id-1]==0)
				return -1;
			else{
				m[id-1]--;
				if(id==4)
					cnt--;
				else
					m[id]++;
			}
			
		}
		
	}
	if(cnt>0)
		return -1;
	else
		return ans;
}

在这里插入图片描述
考虑到提交的时间和内存情况都有浮动,代码里面能优化的部分已经几乎没有了,所以这道题基本也就这样。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/495288.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

如何根据参考文献查找原文及详细的文献信息

当我们已知参考文献想要查看下载原文以及相关信息时可以用下面的方法&#xff1a; 例如这篇参考文献&#xff1a;Alsamhi S H, Almalki F, Ma O, et al. Predictive estimation of optimal signal strength from drones over IoT frameworks in smart cities[J]. IEEE Transac…

FPGA实现SDI视频解码PCIE传输 提供工程源码和QT上位机源码加技术支持

目录 1、前言2、我已有的SDI编解码方案3、我已有的PCIE方案4、总体设计思路和方案SDI摄像头Gv8601a单端转差GTX解串SDI解码VGA时序恢复YUV转RGB图像缓存PCIE发送通路SDI同步输出通路 5、vivado工程详解6、驱动安装7、QT上位机软件8、上板调试验证SDI同步HDMI输出验证PCIE输出验…

neo4j结合gds实现最短路径算法

背景&#xff1a;Neo4j自带的cypher语句中的 shortestpath allShortestPaths 返回值内容非常有限&#xff0c;不易处理, 在实际生产环境中可用性极低&#xff0c; 且若带where条件查询时&#xff0c;查询效率极低 因此&#xff0c;使用Neo4j自带的插件如apoc来进行最短路径查询…

使用@Autowired、@Qualifier、@Primary注解自动装配组件

1.Autowired、Qualifier、Primary注解 1.1.Autowired注解 Autowired注解可以对类成员变量、方法和构造函数进行标注&#xff0c;完成自动装配的工作。 package org.springframework.beans.factory.annotation;import java.lang.annotation.Documented; import java.lang.ann…

hexo stellar主题添加运行时间-利用不蒜子

在网站的页脚想添加博客运行的时间以及&#xff0c;查了一下资料&#xff0c;根据下面的这个博主的代码进行了修改。 打造一个舒服的写作环境&#xff08;Hexo&#xff09; 下面我们开始修改&#xff1a; stellar/layout/_partial/main/footer.ejs 找到//footer的 这一段 // …

基于logback 实现springboot的日志配置

目录 一、前言 二、使用详解 2.1、打印到文件中 2.2、打印级别控制 2.3、logback 详细配置 2.4、logback 配置文件的组成 2.4.1、<root>标签 2.4.2、<contextName>标签 2.4.3、<property>标签 2.4.4、<appender>标签 2.4.5、<logger&g…

Mysql索引(2):索引结构

1 概述 MySQL的索引是在存储引擎层实现的&#xff0c;不同的存储引擎有不同的索引结构&#xff0c;主要包含以下几种&#xff1a; 索引结构描述BTree索最常见的索引类型&#xff0c;大部分引擎都支持 B 树索引 Hash索引 底层数据结构是用哈希表实现的, 只有精确匹配索引列的…

ShardingProxy分库分表实战

目录 ShardingProxy简述 快速使用 ShardingProxy部署 ShardingProxy使用 ShardingProxy的服务治理 Shardingproxy的其他功能 ShardingProxy的SPI扩展 ShardingSphere总结 ShardingProxy简述 ShardingProxy的功能同样是分库分表&#xff0c;但是他是一个独立部署的服务…

林曦讲座 | 关于“无用之美”的11个闪光

林曦老师的新书《无用之美》即将和大家见面啦~    究竟什么是“无用之美”呢&#xff1f;早在2013年&#xff0c;林曦老师就曾在“一席”做过一场关于“无用之美”的分享。2019年又在微软做过一次《中国人的闲情逸致——无用之美》的演讲。这次将两次演讲的内容精华整理出来…

【LeetCode】14. 最长公共前缀

1. 问题 编写一个函数来查找字符串数组中的最长公共前缀。 如果不存在公共前缀&#xff0c;返回空字符串 “”。 示例 1 输入&#xff1a;strs [“flower”,“flow”,“flight”] 输出&#xff1a;“fl” 示例 2 输入&#xff1a;strs [“dog”,“racecar”,“car”] 输出…

虹科动态 | 2023成都国际工业博览会精彩瞬间回顾

2023成都国际工业博览会&#xff08;CDIIF&#xff09;于中国国际西部博览城圆满落下帷幕。本届成都工博会紧紧围绕“工业引领&#xff0c;赋能产业新发展”主题&#xff0c;聚焦工业自动化、数控机床与金属加工、机器人、新一代信息技术与应用、工业互联网、新材料、节能与工业…

在VMware上对于CentOS虚拟机的克隆

一. 执行克隆操作 对已有的虚拟机右键&#xff0c;找到克隆操作&#xff0c;选择完整克隆&#xff0c;之后修改一下虚拟机名称和位置&#xff0c;点击完成即可。 克隆之后还需要修改一些东西&#xff0c;以防止运行期间的 ip 浮动之类的问题。 二. 修改配置 先关闭原来的虚拟…

三菱GOT2000人机界面设置用户报警和系统报警弹出报警显示的具体方法

三菱GOT2000人机界面设置用户报警和系统报警弹出报警显示的具体方法 弹出报警显示功能可以将用户报警、系统报警直接显示再各窗口上起到提示作用,在不切换窗口的情况下直观的提示客户当前设备报警信息。 该功能可以实现将当前发生的用户和系统报警,显示在各个窗口的指定位置(…

Springboot整合Jasypt实战

Springboot整合Jasypt实战 引入依赖 <dependency><groupId>com.github.ulisesbocchio</groupId><artifactId>jasypt-spring-boot-starter</artifactId><version>3.0.5</version> </dependency>配置jasypt # 配置jasypt相关信息…

PowerShell系列(一):PowerShell介绍和cmd命令行的区别

目录 1、cmd命令行窗口有哪些缺点呢&#xff1f; 2、PowerShell的产生 3、PowerShell优点 4、PowerShell使用场景 什么是Windows系统的命令行环境&#xff0c;之前我们在使用XP、Win7系统的时候&#xff0c;用的最多的就是微软官方自带的cmd命令窗口了&#xff0c;我们通过敲命…

面向万物智联的应用框架的思考和探索(下)

原文&#xff1a;面向万物智联的应用框架的思考和探索&#xff08;下&#xff09;&#xff0c;点击链接查看更多技术内容。 应用框架&#xff0c;是操作系统连接开发者生态&#xff0c;实现用户体验的关键基础设施。其中&#xff0c;开发效率和运行体验是永恒的诉求&#xff0c…

导轨式传感器差分信号转换模块隔离放大变送器0-±10mV/0-±20mV转0-10V/4-20mA

概述&#xff1a; DIN11 IPO 压力应变桥信号处理系列隔离放大器是一种将差分输入信号隔离放大、转换成按比例输出的直流信号导轨安装变送模块。产品广泛应用在电力、远程监控、仪器仪表、医疗设备、工业自控等行业。此系列模块内部嵌入了一个高效微功率的电源&#xff0c;向输…

Android+opencv实时人脸与人眼检测案例分享

软件版本&#xff1a; Android Studio Electric Eel 2022.1.1 Patch 2 https://sourceforge.net/projects/opencvlibrary/files/4.5.0/opencv-4.5.0-android-sdk.zip/download 创建工程并导入opencv sdk: 导入opencv sdk: File->New->Import Module 添加工程依赖&am…

如何利用超融合提升制造业开发测试效率 [附用户案例]

进入数字时代&#xff0c;越来越多的制造业企业正在通过自主研发的方式加速应用创新。由于研发效率在很大程度上取决于支持开发测试的服务器、存储等 IT 基础设施的性能&#xff0c;企业需要简单、灵活、高性能的 IT 基础架构&#xff0c;来为研发团队提供资源共享与快速交付支…

Windows微信可以上网但是浏览器却用不了网络如何解决

1、清除DNS缓存。这个主要用于某些网站打不开的情形。 首先同时按WINDOWSR键&#xff0c;在弹出窗口输入CMD&#xff0c;然后回车。 在弹出的命令提示符中输入ipconfig /flushdns&#xff0c;然后回车。 2、重置winsock目录&#xff0c;在命令提示符中输入netsh winsock reset&…