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

华为OD机试 - 字符串消除 - 栈Stack(Python/JS/C/C++ 2024 C卷 100分)

在这里插入图片描述

华为OD机试 2024E卷题库疯狂收录中,刷题点这里

专栏导读

本专栏收录于《华为OD机试真题(Python/JS/C/C++)》。

刷的越多,抽中的概率越大,私信哪吒,备注华为OD,加入华为OD刷题交流群,每一题都有详细的答题思路、详细的代码注释、3个测试用例、为什么这道题采用XX算法、XX算法的适用场景,发现新题目,随时更新。

一、题目描述

游戏规则: 输入一个只包含英文字母的字符串, 字符串中的两个字母如果相邻且相同,就可以消除。 在字符串上反复执行消除的动作, 直到无法继续消除为止,此时游戏结束。 输出最终得到的字符串长度。

二、输入描述

输入原始字符串str 只能包含大小写英文字母,字母的大小写敏感, str长度不超过100

三、输出描述

输出游戏结束后,最终得到的字符串长度。

四、测试用例

测试用例1

1、输入

gg

2、输出

0

3、说明

gg可以直接消除 得到空串 长度为0

测试用例2

1、输入

nezhaahZe

2、输出

5

五、解题思路

1、list倒序循环中

  1. 利用list倒序循环中可以删除元素的特性,删除相邻的相同字符。
  2. 如果循环后,有字符抵消,则递归。

2、栈Stack

  1. 定义Stack,存储没有抵消的字符
  2. 栈顶元素和当前元素一致,则抵消
  3. 不一致,则加入栈
  4. 输出栈的大小即结果

六、Python算法源码

# 定义函数来处理字符消除
def remove_adjacent_duplicates(s):stack = []for char in s:# 检查栈顶元素是否与当前字符相同if stack and stack[-1] == char:stack.pop()  # 消除else:stack.append(char)  # 添加到栈return len(stack)  # 返回栈的长度# 测试用例
print(remove_adjacent_duplicates("gg"))  # 输出 0
print(remove_adjacent_duplicates("nezhaahZe"))  # 输出 5

七、JavaScript算法源码

// 定义函数来处理字符消除
function removeAdjacentDuplicates(s) {let stack = [];for (let char of s) {// 检查栈顶元素是否与当前字符相同if (stack.length > 0 && stack[stack.length - 1] === char) {stack.pop();  // 消除} else {stack.push(char);  // 添加到栈}}return stack.length;  // 返回栈的长度
}// 测试用例
console.log(removeAdjacentDuplicates("gg"));  // 输出 0
console.log(removeAdjacentDuplicates("nezhaahZe"));  // 输出 5

八、C算法源码

#include <stdio.h>
#include <string.h>int remove_adjacent_duplicates(char *s) {char stack[101];  // 假设最大长度为100,栈多分配1int top = -1;  // 栈顶索引for (int i = 0; s[i]; i++) {// 检查栈顶元素是否与当前字符相同if (top != -1 && stack[top] == s[i]) {top--;  // 消除} else {stack[++top] = s[i];  // 添加到栈}}return top + 1;  // 返回栈的长度
}// 测试用例
int main() {printf("%d\n", remove_adjacent_duplicates("gg"));  // 输出 0printf("%d\n", remove_adjacent_duplicates("nezhaahZe"));  // 输出 5return 0;
}

九、C++算法源码

#include <iostream>
#include <stack>
#include <string>int removeAdjacentDuplicates(const std::string& s) {std::stack<char> stack;  // 创建栈for (char c : s) {// 检查栈顶元素是否与当前字符相同if (!stack.empty() && stack.top() == c) {stack.pop();  // 消除} else {stack.push(c);  // 添加到栈}}return stack.size();  // 返回栈的长度
}// 测试用例
int main() {std::cout << removeAdjacentDuplicates("gg") << std::endl;  // 输出 0std::cout << removeAdjacentDuplicates("nezhaahZe") << std::endl;  // 输出 5return 0;
}

🏆下一篇:华为OD机试真题 - 简易内存池(Python/JS/C/C++ 2024 E卷 200分)

🏆本文收录于,华为OD机试真题(Python/JS/C/C++)

刷的越多,抽中的概率越大,私信哪吒,备注华为OD,加入华为OD刷题交流群,每一题都有详细的答题思路、详细的代码注释、3个测试用例、为什么这道题采用XX算法、XX算法的适用场景,发现新题目,随时更新。

在这里插入图片描述


http://www.mrgr.cn/news/63078.html

相关文章:

  • C#中通道(Channels)的应用之(生产者-消费者模式)
  • qt 窗口(window/widget)绘制/渲染顺序 QPainter QPaintDevice Qpainter渲染 失效 无效 原因
  • 2_CSS3 背景 --[CSS3 进阶之路]
  • 如何在 Linux、MacOS 以及 Windows 中打开控制面板
  • 慧集通(DataLinkX)iPaaS集成平台-业务建模之业务对象(二)
  • verilogHDL仿真详解
  • 【Rust标准库中的convert(AsRef,From,Into,TryFrom,TryInto)】
  • wordpress argon主题美化方面
  • 查看VPC之间的互访流量
  • (C#面向初学者的 .NET 的生成 AI) 第 1 部分-简介
  • STM32(hal库)中Systick是如何默认进行计时1ms的?
  • 2024年【广东省安全员C证第四批(专职安全生产管理人员)】新版试题及广东省安全员C证第四批(专职安全生产管理人员)复审考试
  • C语言函数指针实用总结
  • 存在sql注入的公网站点
  • 详细分析SQL state [99999]; error code [17059]; 无法转换为内部表示 解决方法(实战讲解)
  • DICOM基础:CT类型DICOM图像信息头分析
  • 手撕代码:C#.NET实现自定义IOC容器
  • 【C++】类和对象(九):再谈构造函数
  • python画图|errorbar初探
  • 鸿蒙NEXT开发笔记(九)仿微信聊天App的收发文本消息
  • 无人机救援系统基本组成
  • 选项卡设计与实现
  • Python酷库之旅-第三方库Pandas(183)
  • [数组基础] 0724. 寻找数组的中心下标
  • 机器学习算法之回归算法
  • Java中跳转结构