【基础算法总结】模拟篇

目录

  • 一,算法介绍
  • 二,算法原理和代码实现
    • 1576.替换所有的问号
    • 495.提莫攻击
    • 6.Z字形变换
    • 38.外观数列
    • 1419.数青蛙
  • 三,算法总结

一,算法介绍

模拟算法本质就是"依葫芦画瓢",就是在题目中已经告诉了我们该如何操作,我们只要把题目中的过程转化成代码即可。特点是思路简单,难点是十分考验代码功底

二,算法原理和代码实现

1576.替换所有的问号

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

算法原理:

没有那么多弯弯绕绕,就是从前往后遍历字符串,如果出现 ‘?’,就用26个字母判断一个 ‘?’ 字符的前一个和后一个字符,保证不出现前后两个连续相同的字符,再把 ‘?’ 替换即可

细节问题:

要注意边界情况的判断,就是当 ‘?’ 出现在第一个位置和最后一个位置的处理

代码实现:

class Solution 
{
public:string modifyString(string s) {int n = s.size();for(int i = 0; i < n; i++){if(s[i] == '?'){for(char ch = 'a'; ch <= 'z'; ch++){if((i == 0 || s[i-1] != ch) && (i == n-1 || s[i+1] != ch)){s[i] = ch;break;}}}}return s;}
};

495.提莫攻击

在这里插入图片描述
在这里插入图片描述

算法原理:

根据示例,可以得到下面的规律:
在这里插入图片描述

代码实现:

class Solution {
public:int findPoisonedDuration(vector<int>& timeSeries, int duration) {int n = timeSeries.size();int ret = 0;for(int i = 1; i <= n-1; i++){int x = timeSeries[i] - timeSeries[i-1];if(x >= duration)ret += duration;else ret += x;}return ret + duration;}
};

6.Z字形变换

在这里插入图片描述
在这里插入图片描述

算法原理:

我们不直接把字符进行Z变换,把每个字符的下标抽象出来
在这里插入图片描述
然后在表中找出下标的规律,直接在字符串中根据找出的下标取字符
在这里插入图片描述

细节问题:

当给定行数为 1 行时,计算的公差 d == 0,会造成死循环。所以要特殊处理,此时直接返回原字符串即可

代码实现:

class Solution 
{
public:string convert(string s, int numRows) {// 处理特殊情况if(numRows == 1) return s;int d = 2 * numRows - 2, n = s.size();string ret;// 处理第一行的字符for(int i = 0; i < n; i += d)ret += s[i];// 出来中间行的字符for(int k = 1; k < numRows-1; k++) // 枚举中间的每一行{for(int i = k, j = d - k; i < n || j < n; i += d, j += d){if(i < n) ret += s[i];if(j < n) ret += s[j];}}// 处理最后一行字符for(int i = numRows-1; i < n; i += d)ret += s[i];return ret;}
};

38.外观数列

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

算法原理:

本题使用:模拟+双指针
这里的双指针的作用就是从前往后遍历相同字符的区域,计算出相同字符的个数
在这里插入图片描述

代码实现:

class Solution 
{
public:string countAndSay(int n) {if(n == 1) return to_string(1);string ret;string tmp = to_string(1);for(int i = 0; i < n-1; i++){ret = "";int left = 0, right = 0, len = tmp.size();while(right < len){while(right < len && tmp[right] == tmp[left]) right++;ret += to_string(right - left) + tmp[left];left = right;}tmp = ret;}return tmp;}
};

1419.数青蛙

在这里插入图片描述
在这里插入图片描述

算法原理:

这道题在模拟算法中是一道比较难的题
使用:模拟+哈希表
遍历所给的字符串,与叫声字符串进行对比映射
在这里插入图片描述
通过模拟,可以进行总结
在这里插入图片描述

细节处理:

(1) 两个哈希表的作用
第一个哈希表用数组模拟,目的是统计字符出现的个数,但不是用字符进行映射统计的,而是根据叫声字符串 "croak"的下标
第二个哈希表用 hash< char, int > 实现,表示的是叫声字符串"croak"的每个字符,和每个字符对应的下标
(2) 当遍历完整个 croakOfFrogs 字符串后,还需要把第一个哈希表遍历检查一下

代码实现:

根据上面的总结,实现代码有多种方式,下面的实现方式是一种通用的,因为可能有些题目给的叫声字符串不是只有五个字符的"croak",而是其他更长的

class Solution 
{
public:int minNumberOfFrogs(string croakOfFrogs) {string t = "croak";int n = t.size();vector<int> hash(n); // 用数组模拟哈希unordered_map<char, int> index; // [x,x这个字符的下标]for(int i = 0; i < n; i++)index[t[i]] = i;for(auto ch : croakOfFrogs){if(ch == 'c'){// 判断最后一个字符是否存在if(hash[n-1] != 0) hash[n-1]--;hash[0]++; }else{int i = index[ch]; // 找到字符的下标if(hash[i-1] == 0) return -1;else hash[i-1]--, hash[i]++;}}// 除了最后一个字符'k'外,其他字符如果还有出现,直接返回-1for(int i = 0; i < n-1; i++)if(hash[i] != 0) return -1;return hash[n-1];}
};

三,算法总结

解决有关模拟类的题型,最重要的就是根据题目写代码。有些模拟题可能正面做困难,进行优化时一般都是"找规律"进行转换

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

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

相关文章

【记录】大模型|Windows 下 Hugging Face 上的模型的通用极简调用方式之一

这篇文是参考了这篇&#xff0c;然后后来自己试着搭了一下&#xff0c;记录的全部过程&#xff1a;【翻译】Ollama&#xff5c;如何在 Ollama 中运行 Hugging Face 中的模型_ollama 导入 huggingface-CSDN 博客 另外还参考了这篇&#xff1a;无所不谈,百无禁忌,Win11 本地部署无…

【大模型】AutoDL部署AI绘图大模型Stable Diffusion使用详解

目录 一、前言 二、AI绘图大模型概述 2.1 AI绘图大模型介绍 2.2 AI绘图大模型特点 2.3 AI绘图大模型优势 三、主流的AI绘图大模型介绍 3.1 Midjourney 3.1.1 Midjourney介绍 3.1.2 Midjourney功能特点 3.1.3 Midjourney使用场景 3.2 Stable Diffusion 3.2.1 Stable …

【WRF运行第二期(Ubuntu)】ARWpost安装

WRF运行第二期&#xff1a;ARWpost安装 1 ARWpost介绍2 ARWpost安装2.1 ARWpos_V3安装前准备2.2 安装ARWpos2.3 修改Makefile文件2.4 修改configure.arwp文件2.5 生成可执行文件EXE2.6 修改namelist.ARWpost 参考 1 ARWpost介绍 ARWpost 是WRF模型后处理程序之一&#xff0c;用…

前端组件库Element UI 的使用

一、准备工作 1.确保安装了开发软件 VS Code&#xff08;此处可查阅安装 VS Code教程&#xff09;&#xff0c;确保相关插件安装成功 2.安装Node.js 和创建Vue项目&#xff08;此处可查阅安装创建教程&#xff09; 3.成功在VS Code运行一个Vue项目&#xff08;此处可查阅运行…

技术周总结 09.16~09.22 周日(架构 C# 数据库)

文章目录 一、09.16 周一1.1&#xff09;问题01&#xff1a; 软件质量属性中"质量属性场景"、"质量属性环境分析"、"质量属性效用树"、"质量属性需求用例分析"分别是什么&#xff1f;1.2&#xff09;问题02&#xff1a; 软件质量属性中…

MOS工作的三种状态及其分析——亚阈值区(截至区),深三极管区(又叫深线性区)和饱和区

1.MOS工作的三种状态及其分析——亚阈值区&#xff08;截至区&#xff09;&#xff0c;深三极管区&#xff08;又叫深线性区&#xff09;和饱和区。 1.1亚阈值区&#xff08;现代深亚微米工艺下的部分截至区&#xff09; 现代深亚微米工艺下&#xff0c;亚阈值区是指在Vgs小于阈…

WebLogic远程代码执行漏洞CVE-2020-14882

1.环境搭建 cd vulhub-master/weblogic/CVE-2020-14882 docker-compose up -d 2.登录后台 使用以下url绕过登录认证 主页 - base_domain - WLS 控制台http://47.121.211.205:7001/console/css/%252e%252e%252fconsole.portal 3.在目标服务器创建文件 http://47.121.211.…

Linux-gcc/g++

系列文章目录 C语言中的编译和链接 文章目录 系列文章目录一、编译过程gcc如何完成过程在这里涉及到一个重要的概念:函数库 二、动态库、静态库2.1 函数库一般分为静态库和动态库两种。 三、gcc选项gcc选项记忆 一、编译过程 具体过程在这一片c语言文章中讲解过:C语言中的编…

【记录】Excel|不允许的操作:合并或隐藏单元格出现的问题列表及解决方案

人话说在前&#xff1a;这篇的内容是2022年5月写的&#xff0c;当时碰到了要批量处理数据的情况&#xff0c;但是又不知道数据为啥一直报错报错报错&#xff0c;说不允许我操作&#xff0c;最终发现是因为存在隐藏的列或行&#xff0c;于是就很无语地写了博客&#xff0c;但内容…

STM32系统时钟

时钟为单片机提供了稳定的机器周期&#xff0c;从而使我们的系统能够正常的运行 时钟就像我们人的心脏&#xff0c;一旦有问题就整个都会崩溃 stm32有很多外设&#xff0c;但不是所有的外设都使用同一种时钟频率工作&#xff0c;比如我们的内部看门狗和RTC 只要30几k的频率就…

【PLW003】设备器材云端管理平台v1.0(SpringBoot+Mybatis+NodeJS+MySQL前后端分离)

设备器材云端管理平台是一种专为各种设备&#xff08;如教育行业中的实验设备、建筑行业中的施工设备等&#xff09;租赁或共享孵化的数字化管理工具&#xff0c;旨在融合数字化手段&#xff0c;提高各种设备器材的管理效率、 确保设备的安全稳定运行&#xff0c;并优化资源使用…

【Godot4.3】基于状态切换的游戏元素概论

提示 本文的设想性质比较大,只是探讨一种设计思路。完全理论阶段&#xff0c;不可行就当是闹了个笑话O(∩_∩)O哈哈~但很符合我瞎搞的气质。 概述 一些游戏元素&#xff0c;其实是拥有多个状态的。比如一个宝箱&#xff0c;有打开和关闭两个状态。那么只需要设定两个状态的图…

日志系统第五弹:同步日志器模块

日志系统第五弹&#xff1a;同步日志器模块 一、Logger类的设计1.功能2.如何打印日志3.设计 - - - 成员变量1.日志输出限制等级2.资源整合3.唯一标识4.互斥锁 4.设计 - - - 成员函数1.对外的日志打印接口2.抽象的日志实际落地接口3.其他接口 5.Logger类的框架 二、Logger类的实…

springboot地方特色美食分享系统-计算机毕业设计源码02383

摘要 本论文主要论述了如何使用SpringBoot技术开发一个地方特色美食分享系统&#xff0c;本系统将严格按照软件开发流程进行各个阶段的工作&#xff0c;采用B/S架构&#xff0c;面向对象编程思想进行项目开发。在引言中&#xff0c;作者将论述地方特色美食分享系统的当前背景以…

DHCP服务器搭建

1. DHCP工作原理 DHCP动态分配IP地址&#xff0c;客户端广播&#xff0c;服务端单播 2. DHCP服务器安装 2.1 安装DHCP # yum install -y dhcp-server 2.2 修改配置文件 # cd /etc/dhcp/ # ls # vi dhcpd.conf dhcpd.conf 主配置文件 第一行&#xff1a;全局dhcp服务器地…

240922-Ollama使用Embedding实现RAG

A. 最终效果 B. 参考代码 # [嵌入模型 Ollama 博客 - Ollama 中文](https://ollama.org.cn/blog/embedding-models)# 步骤1&#xff1a;生成嵌入import ollama import chromadbdocuments ["Llamas are members of the camelid family meaning theyre pretty closely re…

Golang | Leetcode Golang题解之第423题从英文中重建数字

题目&#xff1a; 题解&#xff1a; func originalDigits(s string) string {c : map[rune]int{}for _, ch : range s {c[ch]}cnt : [10]int{}cnt[0] c[z]cnt[2] c[w]cnt[4] c[u]cnt[6] c[x]cnt[8] c[g]cnt[3] c[h] - cnt[8]cnt[5] c[f] - cnt[4]cnt[7] c[s] - cnt[6]…

手势识别-Yolov5模型-自制数据集训练

1、源码下载&#xff1a; 大家可以直接在浏览器搜索yolov5即可找到官方链接&#xff0c;跳转进github进行下载&#xff1a; 这里对yolov5模型补充说明一下&#xff0c;它是存在较多版本的&#xff0c;具体信息可在master->tags中查看&#xff0c;大家根据需要下载。这些不同…

二叉树(链式存储)

文章目录 一、树的基础概念二、二叉树2.1 概念 性质2.2 二叉树的存储2.2 二叉树的基本操作手动创建一棵二叉树遍历&#xff1a;前、中、后、层序获取树中节点的个数获取叶子节点的个数获取第K层节点的个数获取二叉树的高度检测值为value的元素是否存在判断一棵树是不是完全二叉…

青岛特某电新能源有限公司-充电业务流程及数据交互规范-集控前置-精简版V1.0

1 范围 本流程规定了特某电充电终端所属的集控器与特某电云平台前置之间的充电相关业务流程&#xff0c;明确两端之间的请求和响应。 2 术语 云平台&#xff1a;云平台是提供包括充电设备接入&#xff0c;充电设备信息采集&#xff0c;充电设备管 理&#xff0c;充电设备运维…